Go database/sql is a generic interface around SQL (or SQL-like) databases for the Go programming language. To use database/sql with your application, use the Spanner database/sql driver.
The Spannerdatabase/sql driver supports both GoogleSQL-dialect databases and PostgreSQL-dialect databases.
Install the Spanner database/sql driver
To use the Spanner database/sql driver in your
application, add the following module to your go.mod file:
  github.com/googleapis/go-sql-spanner
Use the Spanner database/sql driver
To create a database/sql connection to a Spanner
database, use spanner as the driver name and a fully qualified database name
as the connection string:
GoogleSQL
PostgreSQL
For more information, see the Spanner database/sql driver GitHub repository.
Supported features
The Spanner Go database/sql examples code directory contains ready-to-run examples for commonly used Spanner features.
Performance tips
To get the best possible performance when using the Spanner database/sql driver, follow these best practices:
- Query parameters: Use query parameters instead of inline values in SQL statements. This lets Spanner cache and reuse the execution plan for frequently used SQL statements.
- Database Definition Language (DDL): Group multiple DDL statements into one batch instead of executing them one by one.
- Data Manipulation Language (DML): Group multiple DML statements into one batch instead of executing them one by one.
- Read-only transactions: Use read-only transactions for workloads that only read data. Read-only transactions don't take locks.
- Tags: Use request and transaction tags to troubleshoot.
What's next
- Learn more about using Spanner with the database/sql driver code examples.
- Learn more about database/sql.
- Use GORM with Spanner.
- File a GitHub issue to report a feature request or bug, or to ask a question about the Spanner database/sql driver.