create_table.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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_table (dbTable *table)
  18. {
  19. int col, ncols;
  20. dbColumn *column;
  21. char *colname;
  22. int sqltype;
  23. char buf[500];
  24. dbString sql;
  25. /* dbConnection conn_par; */
  26. G_debug (3, "db__driver_create_table()");
  27. init_error();
  28. db_init_string (&sql);
  29. db_set_string ( &sql, "CREATE TABLE ");
  30. db_append_string ( &sql, db_get_table_name ( table ) );
  31. db_append_string ( &sql, " ( ");
  32. ncols = db_get_table_number_of_columns(table);
  33. for ( col = 0; col < ncols; col++ ) {
  34. column = db_get_table_column (table, col);
  35. colname = db_get_column_name (column);
  36. sqltype = db_get_column_sqltype (column);
  37. G_debug ( 3, "%s (%s)", colname, db_sqltype_name(sqltype) );
  38. if ( col > 0 ) db_append_string ( &sql, ", " );
  39. db_append_string ( &sql, colname );
  40. db_append_string ( &sql, " " );
  41. switch ( sqltype )
  42. {
  43. case DB_SQL_TYPE_SMALLINT:
  44. db_append_string ( &sql, "SMALLINT");
  45. break;
  46. case DB_SQL_TYPE_INTEGER:
  47. db_append_string ( &sql, "INT");
  48. break;
  49. case DB_SQL_TYPE_REAL:
  50. db_append_string ( &sql, "FLOAT");
  51. break;
  52. /* TODO: better numeric types */
  53. case DB_SQL_TYPE_DOUBLE_PRECISION:
  54. case DB_SQL_TYPE_DECIMAL:
  55. case DB_SQL_TYPE_NUMERIC:
  56. case DB_SQL_TYPE_INTERVAL:
  57. db_append_string ( &sql, "DOUBLE");
  58. break;
  59. /* GRASS does not distinguish TIMESTAMP and DATETIME */
  60. /*
  61. case DB_SQL_TYPE_DATETIME|DB_DATETIME_MASK:
  62. db_append_string ( &sql, "DATETIME");
  63. break;
  64. */
  65. case DB_SQL_TYPE_TIMESTAMP:
  66. /* db_append_string ( &sql, "TIMESTAMP"); */
  67. db_append_string ( &sql, "DATETIME");
  68. break;
  69. case DB_SQL_TYPE_DATE:
  70. db_append_string ( &sql, "DATE");
  71. break;
  72. case DB_SQL_TYPE_TIME:
  73. db_append_string ( &sql, "TIME");
  74. break;
  75. case DB_SQL_TYPE_CHARACTER:
  76. sprintf (buf, "VARCHAR(%d)",
  77. db_get_column_length (column) );
  78. db_append_string ( &sql, buf);
  79. break;
  80. case DB_SQL_TYPE_TEXT:
  81. db_append_string ( &sql, "TEXT");
  82. break;
  83. default:
  84. G_warning ( "Unknown column type (%s)", colname);
  85. return DB_FAILED;
  86. }
  87. }
  88. db_append_string ( &sql, " )" );
  89. G_debug (3, " SQL: %s", db_get_string(&sql) );
  90. if ( mysql_query ( connection, db_get_string(&sql) ) != 0 )
  91. {
  92. append_error( "Cannot create table:\n");
  93. append_error( db_get_string(&sql) );
  94. append_error( "\n" );
  95. append_error ( mysql_error(connection) );
  96. report_error();
  97. db_free_string ( &sql);
  98. return DB_FAILED;
  99. }
  100. /* Grant privileges */
  101. /*
  102. * 1) MySQL does not support user groups but it is possible
  103. * to specify list of users.
  104. * 2) Only root can grant privileges.
  105. */
  106. /*
  107. db_get_connection(&conn_par);
  108. if ( conn_par.group )
  109. {
  110. db_set_string ( &sql, "GRANT SELECT ON on " );
  111. db_append_string ( &sql, db_get_table_name ( table ) );
  112. db_append_string ( &sql, " TO " );
  113. db_append_string ( &sql, conn_par.group );
  114. G_debug (3, " SQL: %s", db_get_string(&sql) );
  115. if ( mysql_query ( connection, db_get_string(&sql) ) != 0 )
  116. {
  117. G_warning ( "Cannot grant select on table: \n%s\n%s",
  118. db_get_string(&sql), mysql_error(connection) );
  119. }
  120. }
  121. */
  122. db_free_string ( &sql);
  123. return DB_OK;
  124. }