c_create_idx.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. #include <string.h>
  2. #include <grass/dbmi.h>
  3. #include "macros.h"
  4. /*!
  5. \fn int db_create_index (dbDriver *driver, dbIndex *index)
  6. \brief
  7. \return
  8. \param
  9. */
  10. int
  11. db_create_index (dbDriver *driver, dbIndex *index)
  12. {
  13. int ret_code;
  14. /* start the procedure call */
  15. db__set_protocol_fds (driver->send, driver->recv);
  16. DB_START_PROCEDURE_CALL(DB_PROC_CREATE_INDEX);
  17. /* send the arguments to the procedure */
  18. DB_SEND_INDEX (index);
  19. /* get the return code for the procedure call */
  20. DB_RECV_RETURN_CODE(&ret_code);
  21. if (ret_code != DB_OK)
  22. return ret_code; /* ret_code SHOULD == DB_FAILED */
  23. /* get results */
  24. DB_RECV_STRING(&index->indexName);
  25. return DB_OK;
  26. }
  27. /*!
  28. \brief Create unique index
  29. \return
  30. \param
  31. */
  32. int
  33. db_create_index2 (dbDriver *driver, const char *table_name, const char *column_name)
  34. {
  35. int ret;
  36. dbIndex index;
  37. char buf[1000];
  38. const char *tbl;
  39. db_init_index ( &index );
  40. db_alloc_index_columns ( &index, 1 );
  41. tbl = strchr ( table_name, '.' );
  42. if ( tbl == NULL )
  43. tbl = table_name;
  44. else
  45. tbl++;
  46. sprintf ( buf, "%s_%s", tbl, column_name );
  47. db_set_index_name ( &index, buf );
  48. db_set_index_table_name ( &index, table_name );
  49. db_set_index_column_name ( &index, 0, column_name );
  50. db_set_index_type_unique ( &index );
  51. ret = db_create_index ( driver , &index );
  52. db_free_index ( &index );
  53. return ret;
  54. }