main.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. /****************************************************************************
  2. *
  3. * MODULE: db.execute
  4. * AUTHOR(S): Radim Blazek <radim.blazek gmail.com> (original contributor)
  5. * Huidae Cho <grass4u gmail.com>
  6. * Glynn Clements <glynn gclements.plus.com>
  7. * Hamish Bowman <hamish_b yahoo.com>
  8. * Markus Neteler <neteler itc.it>
  9. * Stephan Holl
  10. * Martin Landa <landa.martin gmail.com>
  11. * PURPOSE: process one non-select sql statement
  12. * COPYRIGHT: (C) 2002-2011 by the GRASS Development Team
  13. *
  14. * This program is free software under the GNU General
  15. * Public License (>=v2). Read the file COPYING that
  16. * comes with GRASS for details.
  17. *
  18. *****************************************************************************/
  19. #include <stdlib.h>
  20. #include <string.h>
  21. #include <errno.h>
  22. #include <grass/gis.h>
  23. #include <grass/dbmi.h>
  24. #include <grass/glocale.h>
  25. struct
  26. {
  27. const char *driver, *database, *schema, *sql, *input;
  28. int i;
  29. } parms;
  30. /* function prototypes */
  31. static void parse_command_line(int, char **);
  32. static int get_stmt(FILE *, dbString *);
  33. static int stmt_is_empty(dbString *);
  34. static void error_handler(void *);
  35. int main(int argc, char **argv)
  36. {
  37. dbString stmt;
  38. dbDriver *driver;
  39. dbHandle handle;
  40. int ret;
  41. FILE *fd;
  42. int error;
  43. error = 0;
  44. parse_command_line(argc, argv);
  45. /* read from file or stdin ? */
  46. if (parms.input && strcmp(parms.input, "-") != 0) {
  47. fd = fopen(parms.input, "r");
  48. if (fd == NULL) {
  49. G_fatal_error(_("Unable to open file <%s>: %s"),
  50. parms.input, strerror(errno));
  51. }
  52. }
  53. else {
  54. fd = stdin;
  55. }
  56. /* open DB connection */
  57. db_init_string(&stmt);
  58. driver = db_start_driver(parms.driver);
  59. if (driver == NULL) {
  60. G_fatal_error(_("Unable to start driver <%s>"), parms.driver);
  61. }
  62. db_init_handle(&handle);
  63. db_set_handle(&handle, parms.database, parms.schema);
  64. if (db_open_database(driver, &handle) != DB_OK)
  65. G_fatal_error(_("Unable to open database <%s>"), parms.database);
  66. G_add_error_handler(error_handler, driver);
  67. if (parms.sql) {
  68. /* parms.sql */
  69. db_set_string(&stmt, parms.sql);
  70. ret = db_execute_immediate(driver, &stmt);
  71. }
  72. else { /* parms.input */
  73. while (get_stmt(fd, &stmt)) {
  74. if (stmt_is_empty(&stmt))
  75. continue;
  76. G_debug(3, "sql: %s", db_get_string(&stmt));
  77. ret = db_execute_immediate(driver, &stmt);
  78. if (ret != DB_OK) {
  79. if (parms.i) { /* ignore SQL errors */
  80. G_warning(_("Error while executing: '%s'"),
  81. db_get_string(&stmt));
  82. error++;
  83. }
  84. else {
  85. G_fatal_error(_("Error while executing: '%s'"),
  86. db_get_string(&stmt));
  87. }
  88. }
  89. }
  90. }
  91. db_close_database(driver);
  92. db_shutdown_driver(driver);
  93. exit(error ? EXIT_FAILURE : EXIT_SUCCESS);
  94. }
  95. static void parse_command_line(int argc, char **argv)
  96. {
  97. struct Option *driver, *database, *schema, *sql, *input;
  98. struct Flag *i;
  99. struct GModule *module;
  100. const char *drv, *db, *schema_name;
  101. /* Initialize the GIS calls */
  102. G_gisinit(argv[0]);
  103. /* Set description */
  104. module = G_define_module();
  105. G_add_keyword(_("database"));
  106. G_add_keyword(_("attribute table"));
  107. G_add_keyword(_("SQL"));
  108. module->label = _("Executes any SQL statement.");
  109. module->description = _("For SELECT statements use 'db.select'.");
  110. sql = G_define_standard_option(G_OPT_DB_SQL);
  111. sql->label = _("SQL statement");
  112. sql->description = _("Example: update rybniky set kapri = 'hodne' where kapri = 'malo'");
  113. sql->guisection = _("SQL");
  114. input = G_define_standard_option(G_OPT_F_INPUT);
  115. input->required = NO;
  116. input->label = _("Name of file containing SQL statement(s)");
  117. input->description = _("'-' for standard input");
  118. input->guisection = _("SQL");
  119. driver = G_define_standard_option(G_OPT_DB_DRIVER);
  120. driver->options = db_list_drivers();
  121. driver->guisection = _("Connection");
  122. if ((drv = db_get_default_driver_name()))
  123. driver->answer = (char *) drv;
  124. database = G_define_standard_option(G_OPT_DB_DATABASE);
  125. database->guisection = _("Connection");
  126. if ((db = db_get_default_database_name()))
  127. database->answer = (char *) db;
  128. schema = G_define_standard_option(G_OPT_DB_SCHEMA);
  129. schema->guisection = _("Connection");
  130. if ((schema_name = db_get_default_schema_name()))
  131. schema->answer = (char *) schema_name;
  132. i = G_define_flag();
  133. i->key = 'i';
  134. i->description = _("Ignore SQL errors and continue");
  135. i->guisection = _("Errors");
  136. if (G_parser(argc, argv))
  137. exit(EXIT_SUCCESS);
  138. if (!sql->answer && !input->answer) {
  139. G_fatal_error(_("You must provide <%s> or <%s> option"),
  140. sql->key, input->key);
  141. }
  142. parms.driver = driver->answer;
  143. parms.database = database->answer;
  144. parms.schema = schema->answer;
  145. parms.sql = sql->answer;
  146. parms.input = input->answer;
  147. parms.i = i->answer ? TRUE : FALSE;
  148. }
  149. int get_stmt(FILE * fd, dbString * stmt)
  150. {
  151. char buf[DB_SQL_MAX], buf2[DB_SQL_MAX];
  152. size_t len;
  153. db_zero_string(stmt);
  154. if (G_getl2(buf, sizeof(buf), fd) == 0)
  155. return 0;
  156. strcpy(buf2, buf);
  157. G_chop(buf2);
  158. len = strlen(buf2);
  159. if (buf2[len - 1] == ';') { /* end of statement */
  160. buf2[len - 1] = 0; /* truncate ';' */
  161. }
  162. db_set_string(stmt, buf2);
  163. return 1;
  164. }
  165. int stmt_is_empty(dbString * stmt)
  166. {
  167. char dummy[2];
  168. return (sscanf(db_get_string(stmt), "%1s", dummy) != 1);
  169. }
  170. void error_handler(void *p)
  171. {
  172. dbDriver *driver = (dbDriver *) p;
  173. db_close_database(driver);
  174. db_shutdown_driver(driver);
  175. }