blob: 562e3dcf071a830ae4bd8f877739fe071941f1b4 [file] [log] [blame] [view]
---
title: SQL Database Drivers
---
The database/sql and database/sql/driver packages are designed for using databases from Go and implementing database drivers, respectively.
See the design goals doc:
> http://golang.org/src/pkg/database/sql/doc.txt
## Drivers
Drivers for Go's sql package include:
* **Amazon AWS Athena**: https://github.com/uber/athenadriver
* **AWS Athena**: https://github.com/segmentio/go-athena
* **AWS DynamoDB**: https://github.com/btnguyen2k/godynamo
* **Apache Avatica/Phoenix**: https://github.com/apache/calcite-avatica-go
* **Apache H2**: https://github.com/jmrobles/h2go
* **Apache Hive**: https://github.com/sql-machine-learning/gohive
* **Apache Ignite/GridGain**: https://github.com/amsokol/ignite-go-client
* **Apache Impala**: https://github.com/bippio/go-impala
* **Azure Cosmos DB**: https://github.com/btnguyen2k/gocosmos
* **ClickHouse** (uses [HTTP API](https://clickhouse.tech/docs/en/interfaces/http/)): https://github.com/mailru/go-clickhouse
* **ClickHouse** (uses [native TCP interface](https://clickhouse.tech/docs/en/interfaces/tcp/)): https://github.com/ClickHouse/clickhouse-go
* **CockroachDB**: Use any PostgreSQL driver
* **Couchbase N1QL**: https://github.com/couchbase/go_n1ql
* **DB2 LUW** (uses cgo): https://github.com/asifjalil/cli
* **DB2 LUW** and **DB2/Z with DB2-Connect**: https://bitbucket.org/phiggins/db2cli (Last updated 2015-08)
* **DB2 LUW, z/OS, iSeries and Informix**: https://github.com/ibmdb/go_ibm_db
* **Databricks**: https://github.com/databricks/databricks-sql-go
* **DuckDB**: https://github.com/marcboeker/go-duckdb
* **Exasol**: (pure Go): https://github.com/exasol/exasol-driver-go
* **Firebird SQL**: https://github.com/nakagami/firebirdsql
* **Genji** (pure go): https://github.com/genjidb/genji
* **Google Cloud BigQuery**: https://github.com/solcates/go-sql-bigquery
* **Google Cloud Spanner**: https://github.com/googleapis/go-sql-spanner
* **Google Cloud Spanner**: https://github.com/rakyll/go-sql-driver-spanner
* **MS ADODB**: https://github.com/mattn/go-adodb
* **MS SQL Server** (pure go): https://github.com/microsoft/go-mssqldb
* **MS SQL Server** (uses cgo): https://github.com/minus5/gofreetds
* **MaxCompute**: https://github.com/sql-machine-learning/gomaxcompute
* **MySQL**: https://github.com/go-sql-driver/mysql/ ` [*] `
* **MySQL**: https://github.com/siddontang/go-mysql/ ` [**] ` (also handles replication)
* **MySQL**: https://github.com/ziutek/mymysql ` [*] `
* **ODBC**: https://bitbucket.org/miquella/mgodbc (Last updated 2016-02)
* **ODBC**: https://github.com/alexbrainman/odbc
* **Oracle** (pure go): https://github.com/sijms/go-ora
* **Oracle** (uses cgo): https://github.com/godror/godror
* **Oracle** (uses cgo): https://github.com/mattn/go-oci8
* **Oracle** (uses cgo): https://gopkg.in/rana/ora.v4
* **Postgres** (pure Go): https://github.com/jackc/pgx ` [*] `
* **Postgres** (pure Go): https://github.com/lib/pq ` [*] `
* **Postgres** (uses cgo): https://github.com/jbarham/gopgsqldriver
* **Presto**: https://github.com/prestodb/presto-go-client
* **QL**: https://pkg.go.dev/modernc.org/ql
* **SAP ASE** (pure go): https://github.com/SAP/go-ase
* **SAP ASE** (uses cgo): https://github.com/SAP/cgo-ase
* **SAP HANA** (pure go): https://github.com/SAP/go-hdb
* **SAP HANA** (uses cgo): https://help.sap.com/viewer/0eec0d68141541d1b07893a39944924e/2.0.03/en-US/0ffbe86c9d9f44338441829c6bee15e6.html
* **SQL over REST**: https://github.com/adaptant-labs/go-sql-rest-driver
* **SQLite** (uses cgo): https://github.com/gwenn/gosqlite - Supports SQLite dynamic data typing
* **SQLite** (uses cgo): https://github.com/mattn/go-sqlite3 ` [*] `
* **SQLite** (uses cgo): https://github.com/mxk/go-sqlite
* **SQLite**: (pure go): https://modernc.org/sqlite
* **SQLite**: (pure go): https://github.com/ncruces/go-sqlite3
* **SQLite**: (uses cgo): https://github.com/rsc/sqlite
* **SingleStore**: Use any MySQL driver
* **Snowflake** (pure Go): https://github.com/snowflakedb/gosnowflake
* **Sybase ASE** (pure go): https://github.com/thda/tds
* **Sybase SQL Anywhere**: https://github.com/a-palchikov/sqlago
* **TiDB**: Use any MySQL driver
* **Trino**: https://github.com/trinodb/trino-go-client
* **Vertica**: https://github.com/vertica/vertica-sql-go
* **Vitess**: https://pkg.go.dev/vitess.io/vitess/go/vt/vitessdriver
* **YDB** (pure go): https://github.com/ydb-platform/ydb-go-sdk
* **YQL (Yahoo! Query Language)**: https://github.com/mattn/go-yql
Drivers marked with ` [*] ` are both included in and pass the compatibility test suite at https://github.com/bradfitz/go-sql-test.
Drivers marked with ` [**] ` pass the compatibility test suite but are not currently included in it.