index.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*!
  2. \file db/driver/postgres/index.c
  3. \brief DBMI - Low Level PostgreSQL database driver - index management
  4. \todo implement time zone handling
  5. This program is free software under the GNU General Public License
  6. (>=v2). Read the file COPYING that comes with GRASS for details.
  7. \author Radim Blazek
  8. */
  9. #include <grass/dbmi.h>
  10. #include <grass/glocale.h>
  11. #include "globals.h"
  12. #include "proto.h"
  13. int db__driver_create_index(dbIndex * index)
  14. {
  15. int i, ncols;
  16. PGresult *res;
  17. dbString sql;
  18. G_debug(3, "db__create_index()");
  19. db_init_string(&sql);
  20. ncols = db_get_index_number_of_columns(index);
  21. db_set_string(&sql, "create");
  22. if (db_test_index_type_unique(index))
  23. db_append_string(&sql, " unique");
  24. db_append_string(&sql, " index ");
  25. if (PQserverVersion(pg_conn) >= 90500)
  26. db_append_string(&sql, "if not exists ");
  27. db_append_string(&sql, db_get_index_name(index));
  28. db_append_string(&sql, " on ");
  29. db_append_string(&sql, db_get_index_table_name(index));
  30. db_append_string(&sql, " ( ");
  31. for (i = 0; i < ncols; i++) {
  32. if (i > 0)
  33. db_append_string(&sql, ", ");
  34. db_append_string(&sql, db_get_index_column_name(index, i));
  35. }
  36. db_append_string(&sql, " )");
  37. G_debug(3, " SQL: %s", db_get_string(&sql));
  38. res = PQexec(pg_conn, db_get_string(&sql));
  39. if (!res || PQresultStatus(res) != PGRES_COMMAND_OK) {
  40. db_d_append_error("%s: %s\n%s",
  41. _("Unable to create index"),
  42. db_get_string(&sql),
  43. PQerrorMessage(pg_conn));
  44. db_d_report_error();
  45. PQclear(res);
  46. db_free_string(&sql);
  47. return DB_FAILED;
  48. }
  49. PQclear(res);
  50. db_free_string(&sql);
  51. return DB_OK;
  52. }