This example uses GizmoSQL, a lightweight, high-performance SQL server powered by DuckDB or SQLite that supports Arrow Flight SQL.
Tip
If you already have a GizmoSQL instance running, skip the steps to set up GizmoSQL.
-
Start the GizmoSQL server:
docker run -d --rm -it --init -p 31337:31337 --name gizmosql -e DATABASE_FILENAME=adbc_quickstart.db -e TLS_ENABLED=0 -e GIZMOSQL_PASSWORD=gizmosql_password -e PRINT_QUERIES=1 -e INIT_SQL_COMMANDS='CALL dbgen(sf=0.01);' --pull always gizmodata/gizmosql:latest-slim
-
Install the Flight SQL ADBC driver:
dbc install flightsql
-
Customize the Go program
main.goas needed- Change the connection arguments in the
NewDatabase()calluriis the URI of your GizmoSQL instance. The host and port will depend on your installation (the default port is 31337). The protocol scheme should begrpcorgrpc+tcpif your GizmoSQL instance is not using TLS and should begrpc+tlsotherwise.usernameandpasswordare the username and password of your GizmoSQL admin user (the one specified when starting the instance).- You can optionally use JWT token authentication with GizmoSQL server (see more here) - with username:
tokenand a password value of the JWT token contents.
- Change the connection arguments in the
-
Run the Go program:
go mod tidy go run main.go
The output will look something like this:
record: schema: fields: 3 - r_regionkey: type=int32, nullable - r_name: type=utf8, nullable - r_comment: type=utf8, nullable rows: 5 col[0][r_regionkey]: [0 1 2 3 4] col[1][r_name]: ["AFRICA" "AMERICA" "ASIA" "EUROPE" "MIDDLE EAST"] col[2][r_comment]: ["ar packages. regular excuses among the ironic requests cajole fluffily blithely final requests. furiously express p" "s are. furiously even pinto bea" "c, special dependencies around " "e dolphins are furiously about the carefully " " foxes boost furiously along the carefully dogged tithes. slyly regular orbits according to the special epit"]
-
Stop and remove the Docker container running GizmoSQL:
docker stop gizmosql