官术网_书友最值得收藏!

  • Machine Learning With Go
  • Daniel Whitenack
  • 257字
  • 2021-07-08 10:37:28

Connecting to an SQL database

The first thing we need do before connecting to an SQL-like database is identify the particular database that we will be interacting with and import a corresponding driver. In the following examples, we will be connecting to a Postgres database and will utilize the github.com/lib/pq database driver for database/sql. This driver can be loaded via an empty import (with a corresponding comment):

import (
"database/sql"
"fmt"
"log"
"os"

// pq is the library that allows us to connect
// to postgres with databases/sql.
_ "github.com/lib/pq"
)

Now let's assume that you have exported the Postgres connection string to an environmental variable PGURL. We can easily create an sql.DB value for our connection via the follow code:

// Get the postgres connection URL. I have it stored in
// an environmental variable.
pgURL := os.Getenv("PGURL")
if pgURL == "" {
log.Fatal("PGURL empty")
}

// Open a database value. Specify the postgres driver
// for databases/sql.
db, err := sql.Open("postgres", pgURL)
if err != nil {
log.Fatal(err)
}
defer db.Close()

Note that we need to defer the close method on this value. Also, note that creating this value does not mean that you have made a successful connection to the database. This is merely a value used by database/sql to connect to the database when triggered to do so by certain operations (such as a query).

To ensure that we can make a successful connection to the database, we can use the Ping method:

if err := db.Ping(); err != nil {
log.Fatal(err)
}
主站蜘蛛池模板: 成安县| 得荣县| 朝阳县| 大余县| 安达市| 莆田市| 平乡县| 乐亭县| 澄江县| 邹平县| 富裕县| 商河县| 商都县| 阿坝县| 林口县| 岳池县| 通河县| 邛崃市| 柳河县| 廉江市| 芒康县| 金平| 阳东县| 呼和浩特市| 通海县| 维西| 贡嘎县| 沾益县| 孝义市| 江都市| 宿松县| 拜泉县| 廊坊市| 顺平县| 贺兰县| 博湖县| 富平县| 丰都县| 辰溪县| 曲阜市| 泰宁县|