1grass-odbc(1)               GRASS GIS User's Manual              grass-odbc(1)
2
3
4

ODBC DATABASE DRIVER

6       Communication between GRASS and ODBC database for attribute management:
7
8       GRASS module <->                                            <-->                                                         ODBC Interface                                               <-->                                                         RDBMS
9
10       GRASS                                                        DBMI driver                                                  unixODBC                                                     ODBC driver                                                  PostgreSQL
11
12       Oracle
13
14       ...
15
16

Supported SQL commands

18       All SQL commands supported by ODBC.
19

Operators available in conditions

21       All SQL operators supported by ODBC.
22

EXAMPLE

24       In  this  example  we  copy the dbf file of a SHAPE map into ODBC, then
25       connect GRASS to the ODBC DBMS.  Usually  the  table  will  be  already
26       present in the DBMS.
27
28   Defining the ODBC connection
29   MS-Windows
30       On  MS-Windows,  in  order  to  be able to connect, the ODBC connection
31       needs to be configured using dedicated tools (tool  called  "ODBC  Data
32       Source Administrator") and give a name to that connection. This name is
33       then used as database name when accessing from a client via ODBC.
34
35   Linux
36       Configure ODBC driver for selected database (manually  or  with  ’ODBC‐
37       Config’).  ODBC drivers are defined in /etc/odbcinst.ini. Here an exam‐
38       ple:
39
40        [PostgreSQL]
41        Description     = ODBC for PostgreSQL
42        Driver          = /usr/lib/libodbcpsql.so
43        Setup           = /usr/lib/libodbcpsqlS.so
44        FileUsage       = 1
45
46       Create DSN (data source name). The DSN is used as database name in db.*
47       modules.  Then  DSN  must  be defined in $HOME/.odbc.ini (for this user
48       only) or in /etc/odbc.ini for (for all users) [watch out for the  data‐
49       base name which appears twice and also for the PostgreSQL protocol ver‐
50       sion]. Omit blanks at the beginning of lines:
51
52        [grass6test]
53        Description             = PostgreSQL
54        Driver                  = PostgreSQL
55        Trace                   = No
56        TraceFile               =
57        Database                = grass6test
58        Servername              = localhost
59        UserName                = neteler
60        Password                =
61        Port                    = 5432
62        Protocol                = 8.0
63        ReadOnly                = No
64        RowVersioning           = No
65        ShowSystemTables        = No
66        ShowOidColumn           = No
67        FakeOidIndex            = No
68        ConnSettings            =
69       Configuration   of   an   DSN   without    GUI    is    described    on
70       http://www.unixodbc.org/odbcinst.html,  but  odbc.ini and .odbc.ini may
71       be created by the ’ODBCConfig’ tool.  You  can  easily  view  your  DSN
72       structure  by  ’DataManager’.  Configuration  with  GUI is described on
73       http://www.unixodbc.org/doc/UserManual/
74
75       To find out about your PostgreSQL protocol, run:
76       psql -V
77
78   Using the ODBC driver
79       Now create a new database if not yet existing:
80
81       db.createdb driver=odbc database=grass6test
82
83       To store a table ’mytable.dbf’ (here: in current directory) into  Post‐
84       greSQL through ODBC, run:
85
86       db.connect driver=odbc database=grass6test
87       db.copy from_driver=dbf from_database=./ from_table=mytable \
88               to_driver=odbc to_database=grass6test to_table=mytable
89
90       Next  link  the map to the attribute table (now the ODBC table is used,
91       not the dbf file):
92
93       v.db.connect map=mytable.shp table=mytable key=ID \
94                    database=grass6test driver=odbc
95       v.db.connect -p
96
97       Finally a test: Here we should see the table columns (if the ODBC  con‐
98       nection works):
99       db.tables -p
100       db.columns table=mytable
101
102       Now the table name ’mytable’ should appear.
103       Doesn’t  work?  Check with ’isql <databasename>’ if the ODBC-PostgreSQL
104       connection is really established.
105
106       Note that you can also connect  mySQL,  Oracle  etc.  through  ODBC  to
107       GRASS.
108
109       You can also check the vector map itself concerning a current link to a
110       table:
111
112       v.db.connect -p mytable.shp
113
114       which should print the database connection through ODBC to the  defined
115       RDBMS.
116

SEE ALSO

118        db.connect, v.db.connect, unixODBC web site, SQL support in GRASS GIS
119
120       Main index | Topics index | Keywords index | Graphical index | Full in‐
121       dex
122
123       © 2003-2022 GRASS Development Team, GRASS GIS 8.2.0 Reference Manual
124
125
126
127GRASS 8.2.0                                                      grass-odbc(1)
Impressum