Overview
The Firebolt Go SDK is an implementation of Go’sdatabase/sql/driver interface, enabling Go developers to connect to and interact with Firebolt databases seamlessly.
Prerequisites
You must have the following prerequisites before you can connect your Firebolt account to Go:- Go installed and configured on your system. The minimum supported version is 1.18 or higher. If you do not have Go installed, you can download the latest version. After installing, if you don’t have a Go module yet, you’ll need to initialize one. See the Go documentation on modules for detailed instructions on how to create and initialize a Go module.
- Firebolt account – You need an active Firebolt account. If you do not have one, you can sign up for one.
- Firebolt service account – You must have access to an active Firebolt service account, which facilitates programmatic access to Firebolt, its ID and secret.
- Firebolt user – You must have a user that is associated with your service account. The user should have USAGE permission to query your database, and OPERATE permission to start and stop an engine if it is not already started.
- Firebolt database and engine (optional) – You can optionally connect to a Firebolt database and/or engine. If you do not have one yet, you can create a database and also create an engine. You would need a database if want to access stored data in Firebolt and an engine if you want to load and query stored data.
Installation
To install the Firebolt Go SDK, run the followinggo get command from inside your Go module:
DSN Parameters
Go passes a data source name (DSN) to Firebolt’s Go SDK to connect to Firebolt. The SDK parses the DSN string for parameters to authenticate and connect to a Firebolt account, database, and engine. The DSN string supports the following parameters:- client_id: client ID of your service account.
- client_secret: client secret of your service account.
- account_name: The name of your Firebolt account.
- database: (Optional) The name of the database to connect to.
- engine: (Optional) The name of the engine to run SQL queries on.
Connecting to Firebolt Core
The Firebolt Go SDK can be used to connect to Firebolt Core. The connection process is the same, but the DSN parameters differ. For more information on connecting to Firebolt Core, refer to the Firebolt Core Go SDK documentation. Just for a quick reference, the DSN for Firebolt Core should look like this:Connect to Firebolt
To establish a connection to a Firebolt database, construct a DSN string with your credentials and database details. The following example contains a script to connect to Firebolt that you can place in a file (e.gmain.go) and run using go run main.go inside your Go module:
Run queries
Once connected, you can run SQL queries. The following examples show you how to create a table, insert data, and retrieve data. You can place them inside the previous script under `// Your database operations go here“:Streaming Queries
Firebolt supports streaming large query results usingrows.Next(), allowing efficient processing of large datasets.
If you enable result streaming, the query execution might finish successfully, but the actual error might be returned while iterating the rows.
firebolt-go-sdk/context package to create a context with streaming enabled:
Troubleshooting
When building a DSN to connect with Firebolt using the Go SDK, follow these best practices to ensure correct connection string formatting and avoid parsing errors. The DSN must follow this structure:- Place the database name in the URI path after firebolt:///.
- Use only letters, numbers, and underscores (_) in the database name. Avoid hyphens (-), as they may cause parsing errors.
- Ensure the account_namematches the name shown in the Firebolt Console URL, which is usually lowercase with no special characters.
- Use the exact engine name as shown in the Firebolt Workspace.
- Do not pass the database name as a query parameter. The SDK does not support &database=in the DSN.
Common errors and solutions
| Error message | Likely cause | Solution | 
|---|---|---|
| invalid connection string format | URI format is invalid or it contains illegal characters (like -) | Double check the URI format and remove illegal characters. | 
| unknown parameter name database | Attempted to pass databaseas a query parameter. | Move the database name into the URI path. | 
| error opening database connection | Incorrect connection credentials. | Verify connection parameters values in the Firebolt UI and use exact values. |