printtab.c 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #include <grass/gis.h>
  2. #include <grass/dbmi.h>
  3. #include "local_proto.h"
  4. #include <grass/glocale.h>
  5. int print_table_definition(dbDriver * driver, dbTable * table)
  6. {
  7. int ncols, col, nrows;
  8. dbColumn *column;
  9. char buf[1024];
  10. dbString stmt;
  11. fprintf(stdout, "table:%s\n", db_get_table_name(table));
  12. fprintf(stdout, "description:%s\n", db_get_table_description(table));
  13. print_priv("insert", db_get_table_insert_priv(table));
  14. print_priv("delete", db_get_table_delete_priv(table));
  15. ncols = db_get_table_number_of_columns(table);
  16. db_init_string(&stmt);
  17. sprintf(buf, "select * from %s", db_get_table_name(table));
  18. db_set_string(&stmt, buf);
  19. nrows = db_get_table_number_of_rows(driver, &stmt);
  20. fprintf(stdout, "ncols:%d\n", ncols);
  21. fprintf(stdout, "nrows:%d\n", nrows);
  22. for (col = 0; col < ncols; col++) {
  23. column = db_get_table_column(table, col);
  24. fprintf(stdout, "\n");
  25. print_column_definition(column);
  26. }
  27. return 0;
  28. }
  29. int print_column_definition(dbColumn * column)
  30. {
  31. dbString value_string;
  32. fprintf(stdout, "column:%s\n", db_get_column_name(column));
  33. fprintf(stdout, "description:%s\n", db_get_column_description(column));
  34. fprintf(stdout, "type:%s\n",
  35. db_sqltype_name(db_get_column_sqltype(column)));
  36. fprintf(stdout, "len:%d\n", db_get_column_length(column));
  37. fprintf(stdout, "scale:%d\n", db_get_column_scale(column));
  38. fprintf(stdout, "precision:%d\n", db_get_column_precision(column));
  39. fprintf(stdout, "default:");
  40. if (db_test_column_has_default_value(column)) {
  41. db_init_string(&value_string);
  42. db_convert_column_default_value_to_string(column, &value_string);
  43. fprintf(stdout, "%s", db_get_string(&value_string));
  44. }
  45. fprintf(stdout, "\n");
  46. fprintf(stdout, "nullok:%s\n",
  47. db_test_column_null_allowed(column) ? "yes" : "no");
  48. print_priv("select", db_get_column_select_priv(column));
  49. print_priv("update", db_get_column_update_priv(column));
  50. return 0;
  51. }
  52. int print_priv(char *label, int priv)
  53. {
  54. fprintf(stdout, "%s:", label);
  55. switch (priv) {
  56. case DB_GRANTED:
  57. fprintf(stdout, "yes");
  58. break;
  59. case DB_NOT_GRANTED:
  60. fprintf(stdout, "no");
  61. break;
  62. default:
  63. fprintf(stdout, "?");
  64. break;
  65. }
  66. fprintf(stdout, "\n");
  67. return 0;
  68. }