123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- /**********************************************************
- * MODULE: mysql
- * AUTHOR(S): Radim Blazek (radim.blazek@gmail.com)
- * PURPOSE: MySQL database driver
- * COPYRIGHT: (C) 2001 by the GRASS Development Team
- * This program is free software under the
- * GNU General Public License (>=v2).
- * Read the file COPYING that comes with GRASS
- * for details.
- **********************************************************/
- #include <grass/gis.h>
- #include <grass/dbmi.h>
- #include <grass/glocale.h>
- #include "globals.h"
- #include "proto.h"
- int
- db__driver_create_index ( dbIndex *index )
- {
- int i, ncols;
- dbString sql;
-
- G_debug (3, "db__create_index()");
- db_init_string (&sql);
- init_error();
- ncols = db_get_index_number_of_columns ( index );
- db_set_string ( &sql, "CREATE" );
- if ( db_test_index_type_unique(index) )
- db_append_string ( &sql, " UNIQUE" );
- db_append_string ( &sql, " INDEX " );
- db_append_string ( &sql, db_get_index_name(index) );
- db_append_string ( &sql, " ON " );
-
- db_append_string ( &sql, db_get_index_table_name(index) );
-
- db_append_string ( &sql, " ( " );
- for ( i = 0; i < ncols; i++ ) {
- if ( i > 0 )
- db_append_string ( &sql, ", " );
-
- db_append_string ( &sql, db_get_index_column_name(index,i) );
- }
-
- db_append_string ( &sql, " )" );
- G_debug (3, " SQL: %s", db_get_string(&sql) );
-
- if ( mysql_query ( connection, db_get_string(&sql) ) != 0 )
- {
- append_error( "Cannot create index:\n");
- append_error( db_get_string(&sql) );
- append_error( "\n" );
- append_error ( mysql_error(connection) );
- report_error();
- db_free_string ( &sql);
- return DB_FAILED;
- }
-
- db_free_string ( &sql);
-
- return DB_OK;
- }
|