index.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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 db__driver_create_index(dbIndex * index)
  17. {
  18. int i, ncols;
  19. dbString sql;
  20. G_debug(3, "db__create_index()");
  21. db_init_string(&sql);
  22. init_error();
  23. ncols = db_get_index_number_of_columns(index);
  24. db_set_string(&sql, "CREATE");
  25. if (db_test_index_type_unique(index))
  26. db_append_string(&sql, " UNIQUE");
  27. db_append_string(&sql, " INDEX ");
  28. db_append_string(&sql, db_get_index_name(index));
  29. db_append_string(&sql, " ON ");
  30. db_append_string(&sql, db_get_index_table_name(index));
  31. db_append_string(&sql, " ( ");
  32. for (i = 0; i < ncols; i++) {
  33. if (i > 0)
  34. db_append_string(&sql, ", ");
  35. db_append_string(&sql, db_get_index_column_name(index, i));
  36. }
  37. db_append_string(&sql, " )");
  38. G_debug(3, " SQL: %s", db_get_string(&sql));
  39. if (mysql_query(connection, db_get_string(&sql)) != 0) {
  40. append_error("Cannot create index:\n");
  41. append_error(db_get_string(&sql));
  42. append_error("\n");
  43. append_error(mysql_error(connection));
  44. report_error();
  45. db_free_string(&sql);
  46. return DB_FAILED;
  47. }
  48. db_free_string(&sql);
  49. return DB_OK;
  50. }