/*! \page dbmilib GRASS DataBase Management Interface by GRASS Development Team https://grass.osgeo.org \section dbmiIntro Introduction The attribute management was completely changed in GRASS 6 to achieve multi-attribute capabilities managed within external databases. The former dig_cats/ files (GRASS 5) are not used any more and all vector attributes are stored in external database. Connection with database is done through DBMI library (DataBase Management Interface) with its integrated drivers. At time of this writing following DBMI drivers for attribute storage are available: - DBF: xBase files (default) - ODBC: to interface from http://www.unixodbc.org - PostgreSQL driver (note that PostgreSQL can also be accessed through ODBC): http://www.postgresql.org - mySQL: http://mysql.com/ - SQLite: http://www.sqlite.org These drivers are compiled depending on present DB related libraries and 'configure' settings. Only the DBF driver is always compiled. The default DBMI driver is defined in dbmi.h \code #define DB_DEFAULT_DRIVER "sqlite" \endcode In general records in table are linked to vector entities by field number and category number. The field number identifies a database table and the category number identifies the record record. I.e. for unique combination mapset + map + field + category exists one unique combination driver + database + table + row. Each element may have none, one or more categories (cats). More cats are distinguished by field number (field). The flexibility of this approach even supports the extreme case, that one vector entity may be linked to attributes in different tables in different databases connected by different drivers at the same time. The DBMI library contains drivers such as DBF, SQLite, ODBC, MySQL and PostgreSQL. The functionality of the database support varies with the capabilities of the underlying RDBMS. Main features are multi-attributes support for various data types, also multiple tables may optionally be linked to one or many vector entity/ies. SQL (Structured Query Language) is used for all drivers, but in a limited implementation. For DBMI architecture details please read Blazek et al. 2002 (see below). \section dbmiFunc DBMI library functions The db_*() functions are the programmer's API for GRASS DBMI programming. There are three groups: - dbmi_base: contains functions for modules, drivers (../../db/drivers/) - dbmi_client: contains functions for modules - dbmi_driver: contains functions for drivers (../../db/drivers/) \section dbmiBase DBMI BASE functions Allocation: - db_store() - db_malloc() - db_calloc() - db_realloc() - db_free() String manipulation: - db_char_to_lowercase() - db_char_to_uppercase() - db_Cstring_to_lowercase() - db_Cstring_to_uppercase() - db_nocase_compare() Column properties: - db_get_column_value() - db_get_column_default_value() - db_set_column_sqltype() - db_set_column_host_type() - db_get_column_scale() - db_set_column_scale() - db_get_column_precision() - db_set_column_precision() - db_get_column_sqltype() - db_get_column_host_type() - db_set_column_has_defined_default_value() - db_set_column_has_undefined_default_value() - db_unset_column_has_default_value() - db_test_column_has_default_value() - db_test_column_has_defined_default_value() - db_test_column_has_undefined_default_value() - db_set_column_use_default_value() - db_unset_column_use_default_value() - db_test_column_use_default_value() - db_set_column_null_allowed() - db_unset_column_null_allowed() - db_test_column_null_allowed() - db_get_column_length() - db_set_column_length() - db_set_column_select_priv_granted() - db_set_column_select_priv_not_granted() - db_get_column_select_priv() - db_set_column_update_priv_granted() - db_set_column_update_priv_not_granted() - db_get_column_update_priv() - db_init_column() - db_set_column_name() - db_get_column_name() - db_set_column_description() - db_get_column_description() - db_free_column() - db_copy_column() - db_convert_Cstring_to_column_value() - db_convert_Cstring_to_column_default_value() - db_convert_column_value_to_string() - db_convert_column_default_value_to_string() Connection settings: - db_set_connection() - db_get_connection() Cursor management: - db_init_cursor() - db_alloc_cursor_table() - db_free_cursor() - db_get_cursor_table() - db_set_cursor_table() - db_get_cursor_token() - db_set_cursor_token() - db_set_cursor_type_readonly() - db_set_cursor_type_update() - db_set_cursor_type_insert() - db_test_cursor_type_fetch() - db_test_cursor_type_update() - db_test_cursor_type_insert() - db_set_cursor_mode() - db_set_cursor_mode_scroll() - db_unset_cursor_mode_scroll() - db_unset_cursor_mode() - db_set_cursor_mode_insensitive() - db_unset_cursor_mode_insensitive() - db_test_cursor_mode_scroll() - db_test_cursor_mode_insensitive() - db_alloc_cursor_column_flags() - db_free_cursor_column_flags() - db_set_cursor_column_for_update() - db_unset_cursor_column_for_update() - db_test_cursor_column_for_update() - db_test_cursor_any_column_for_update() - db_set_cursor_column_flag() - db_unset_cursor_column_flag() - db_test_cursor_column_flag() - db_get_cursor_number_of_columns() - db_test_cursor_any_column_flag() DateTime conversion: - db_convert_value_datetime_into_string() - db_convert_Cstring_to_value_datetime() DBmscap management: - db_dbmscap_filename() - db_has_dbms() - db_copy_dbmscap_entry() - db_read_dbmscap() - db_free_dbmscap() Default settings: - db_get_default_driver_name() - db_get_default_database_name() - db_get_default_schema_name() - db_get_default_group_name() - db_set_default_connection() Dirent (directory entities) array: - db_dirent() - db_free_dirent_array() - db_alloc_dirent_array() Report errors: - db_on_error() - db_set_error_who() - db_get_error_who() - db_error() - db_protocol_error() - db_syserror() - db_get_error_code() - db_memory_error() - db_procedure_not_implemented() - db_noproc_error() - db_clear_error() - db_print_error() - db_debug_on() - db_debug_off() - db_debug() - db_get_error_msg() - db_auto_print_errors() - db_auto_print_protocol_errors() Handle management: - db_init_handle() - db_set_handle() - db_get_handle_dbname() - db_get_handle_dbschema() - db_free_handle() - db_free_handle_array() - db_alloc_handle_array() Index management: - db_init_index() - db_free_index() - db_alloc_index_columns() - db_alloc_index_array() - db_free_index_array() - db_set_index_name() - db_get_index_name() - db_set_index_table_name() - db_get_index_table_name() - db_get_index_number_of_columns() - db_set_index_column_name() - db_get_index_column_name() - db_set_index_type_unique() - db_set_index_type_non_unique() - db_test_index_type_unique() - db_print_index() Range functions: - db_interval_range() Login functions: - db_set_login() - db_get_login() Return codes (internal use only): - db__send_success() - db__send_failure() - db__recv_return_code() Data type conversion: - db_sqltype_to_Ctype() - db_sqltype_name() String manipulation: - db_init_string() - db_set_string() - db_set_string_no_copy() - db_sizeof_string() - db_zero_string() - db_enlarge_string() - db_get_string() - db_free_string() - db_free_string_array() - db_alloc_string_array() - db_append_string() - db_copy_string() - db_double_quote_string() Table/privileges management: - db_alloc_table() - db_init_table() - db_free_table() - db_set_table_name() - db_get_table_name() - db_set_table_description() - db_get_table_description() - db_get_table_number_of_columns() - db_set_table_select_priv_granted() - db_set_table_select_priv_not_granted() - db_get_table_select_priv() - db_set_table_update_priv_granted() - db_set_table_update_priv_not_granted() - db_get_table_update_priv() - db_set_table_insert_priv_granted() - db_set_table_insert_priv_not_granted() - db_get_table_insert_priv() - db_set_table_delete_priv_granted() - db_set_table_delete_priv_not_granted() - db_get_table_delete_priv() - db_get_table_column() - db_get_table_column_by_name() - db_set_table_column() - db_append_table_column() - db_clone_table() - db_table_to_sql() Token management: - db_find_token() - db_drop_token() - db_new_token() Value management: - db_test_value_isnull() - db_get_value_int() - db_get_value_double() - db_get_value_as_double() - db_get_value_string() - db_get_value_year() - db_get_value_month() - db_get_value_day() - db_get_value_hour() - db_get_value_minute() - db_get_value_seconds() - db_set_value_null() - db_set_value_not_null() - db_set_value_int() - db_set_value_double() - db_set_value_string() - db_set_value_year() - db_set_value_month() - db_set_value_day() - db_set_value_hour() - db_set_value_minute() - db_set_value_seconds() - db_test_value_datetime_current() - db_set_value_datetime_current() - db_set_value_datetime_not_current() - db_copy_value() - db_CatValArray_init() - db_CatValArray_free() - db_CatValArray_alloc() - db_CatValArray_realloc() - db_convert_Cstring_to_value() - db_convert_value_to_string() Misc: - db_isdir() - db_legal_tablename() - db_whoami \section dbmiClient DBMI CLIENT functions - db_add_column() - db_begin_transaction() - db_bind_update() - db_CatValArray_get_value() - db_CatValArray_get_value_double() - db_CatValArray_get_value_int() - db_CatValArray_sort() - db_CatValArray_sort_by_value() - db_close_cursor() - db_close_database() - db_close_database_shutdown_driver() - db_column_Ctype() - db_column_sqltype() - db_commit_transaction() - db_copy_table() - db_copy_table_where() - db_copy_table_select() - db_copy_table_by_ints() - db_create_database() - db_create_index() - db_create_table() - db_delete() - db_delete_database() - db_delete_table() - db_describe_table() - db_drop_column() - db_drop_index() - db_drop_table() - db_execute_immediate() - db_fetch() - db_find_database() - db_get_column() - db_get_num_rows() - db_get_table_number_of_rows() - db_grant_on_table() - db_gversion() - db_insert() - db_list_databases() - db_list_drivers() - db_list_indexes() - db_list_tables() - db_open_database() - db_open_insert_cursor() - db_open_select_cursor() - db_open_update_cursor() - db_print_column_definition() - db_print_table_definition() - db_start_driver_open_database() - db_select_CatValArray() - db_select_int() - db_select_value() - db_shutdown_driver() - db_start_driver() - db_table_exists() - db_update() \section dbmiDriver DBMI DRIVER functions - db_driver() - db_driver_mkdir() - db_d_add_column() - db_d_append_error() - db_d_begin_transaction() - db_d_bind_update() - db_d_close_cursor() - db_d_close_database() - db_d_commit_transaction() - db_d_create_database() - db_d_create_index() - db_d_create_table() - db_d_delete() - db_d_delete_database() - db_d_describe_table() - db_d_drop_column() - db_d_drop_index() - db_d_drop_table() - db_d_execute_immediate() - db_d_fetch() - db_d_find_database() - db_d_get_num_rows() - db_driver_mkdir() - db_d_grant_on_table() - db_d_init_error() - db_d_insert() - db_d_list_databases() - db_d_list_indexes() - db_d_list_tables() - db_d_open_database() - db_d_open_insert_cursor() - db_d_open_select_cursor() - db_d_open_update_cursor() - db_d_report_error() - db_d_update() \section dbmiReferences References Text based on: R. Blazek, M. Neteler, and R. Micarelli. The new GRASS 5.1 vector architecture. In Open source GIS - GRASS users conference 2002, Trento, Italy, 11-13 September 2002. University of Trento, Italy, 2002. http://www.ing.unitn.it/~grass/proceedings/proceedings/pdfs/Blazek_Radim.pdf \section dbmiSeeAlso See Also GRASS Vector Architecture: \ref vectorlib \section dbmiAuthors Authors - Joel Jones (CERL/UIUC) - Radim Blazek */