1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- /**********************************************************
- * 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;
- }
|