index.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /**********************************************************
  2. * MODULE: mysql
  3. * AUTHOR(S): Radim Blazek (radim.blazek@gmail.com)
  4. * PURPOSE: MySQL database driver
  5. * COPYRIGHT: (C) 2001 by the GRASS Development Team
  6. * This program is free software under the
  7. * GNU General Public License (>=v2).
  8. * Read the file COPYING that comes with GRASS
  9. * for details.
  10. **********************************************************/
  11. #include <grass/gis.h>
  12. #include <grass/dbmi.h>
  13. #include <grass/glocale.h>
  14. #include "globals.h"
  15. #include "proto.h"
  16. int
  17. db__driver_create_index ( dbIndex *index )
  18. {
  19. int i, ncols;
  20. dbString sql;
  21. G_debug (3, "db__create_index()");
  22. db_init_string (&sql);
  23. init_error();
  24. ncols = db_get_index_number_of_columns ( index );
  25. db_set_string ( &sql, "CREATE" );
  26. if ( db_test_index_type_unique(index) )
  27. db_append_string ( &sql, " UNIQUE" );
  28. db_append_string ( &sql, " INDEX " );
  29. db_append_string ( &sql, db_get_index_name(index) );
  30. db_append_string ( &sql, " ON " );
  31. db_append_string ( &sql, db_get_index_table_name(index) );
  32. db_append_string ( &sql, " ( " );
  33. for ( i = 0; i < ncols; i++ ) {
  34. if ( i > 0 )
  35. db_append_string ( &sql, ", " );
  36. db_append_string ( &sql, db_get_index_column_name(index,i) );
  37. }
  38. db_append_string ( &sql, " )" );
  39. G_debug (3, " SQL: %s", db_get_string(&sql) );
  40. if ( mysql_query ( connection, db_get_string(&sql) ) != 0 )
  41. {
  42. append_error( "Cannot create index:\n");
  43. append_error( db_get_string(&sql) );
  44. append_error( "\n" );
  45. append_error ( mysql_error(connection) );
  46. report_error();
  47. db_free_string ( &sql);
  48. return DB_FAILED;
  49. }
  50. db_free_string ( &sql);
  51. return DB_OK;
  52. }