golang 中集成 postgresql 数据库安装:安装 postgresql 驱动、postgresql 数据库和 golang。创建连接池:管理与数据库的连接。执行查询:使用 db.query 方法执行查询。执行更新:使用 db.exec 方法执行更新(插入、更新、删除)。实战案例:使用 rest API 创建资产,并将其存储到 postgresql 数据库中。

Golang 框架如何集成 PostgreSQL 数据库
PostgreSQL 是一款功能强大的开源关系型数据库管理系统,以其可靠性和可扩展性而闻名。在 Golang 中集成 PostgreSQL 可以帮助你轻松地管理数据库连接、查询和数据操作。
先决条件
- 安装和配置 PostgreSQL 数据库
- 安装 Golang 1.18 或更高版本
安装 PostgreSQL 驱动
首先,你需要安装 PostgreSQL 驱动程序以连接到数据库:
|
1
|
$ go get -u Github.com/jackc/pgx/v4
|
创建连接池
接下来,创建一个连接池以管理与数据库的连接。连接池可以提高性能并减少创建和销毁连接的开销:
立即学习“go语言免费学习笔记(深入)”;
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
import (
"context"
"database/sql"
"fmt"
"log"
"time"
"github.com/jackc/pgx/v4"
"github.com/jackc/pgx/v4/stdlib"
)
var db *sql.DB
func initDB() {
connectionString := fmt.Sprintf("user=root password=mysecret dbname=mydatabase host=localhost port=5432")
pool, err := pgx.ParseConfig(connectionString)
if err != nil {
log.Fatalf("unable to parse connection string: %v", err)
}
pool.MaxConnections = 10
pool.MaxConnLifetime = 5 * time.Minute
db = stdlib.OpenDB(*pool)
if err := db.Ping(context.Background()); err != nil {
log.Fatalf("unable to connect to database: %v", err)
}
}
|
执行查询
要执行查询,可以使用 db.Query 方法:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
func queryAssets() ([]*Asset, error) {
rows, err := db.Query("SELECT * FROM assets")
if err != nil {
return nil, fmt.Errorf("query failed: %v", err)
}
defer rows.Close()
var assets []*Asset
for rows.Next() {
var asset Asset
if err := rows.Scan(&asset.ID, &asset.Name); err != nil {
return nil, fmt.Errorf("scan failed: %v", err)
}
assets = append(assets, &asset)
}
return assets, nil
}
|
执行更新
要执行更新(例如插入、更新或删除),可以使用 db.Exec 方法:
|
1
2
3
4
5
6
7
|
func insertAsset(asset Asset) (int64, error) {
result, err := db.Exec("INSERT INTO assets (name) VALUES (?)", asset.Name)
if err != nil {
return 0, fmt.Errorf("insert failed: %v", err)
}
return result.RowsAffected(), nil
}
|
实战案例
考虑一个示例应用程序,其中我们要将用户提交的数据存储到 PostgreSQL 数据库中:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
package main
import (
"encoding/JSon"
"fmt"
"log"
"net/HTTP"
"github.com/gorilla/mux"
)
type Asset struct {
ID int `JSON:"id"`
Name string `json:"name"`
}
func main() {
initDB()
r := mux.NewRouter()
r.HandleFunc("/assets", createAsset).Methods("POST")
log.Fatal(http.ListeNANDServe(":8080", r))
}
func createAsset(w http.ResponseWriter, r *http.Request) {
var asset Asset
if err := json.NewDecoder(r.Body).Decode(&asset); err != nil {
http.Error(w, "Invalid request body", http.StatusBadRequest)
return
}
id, err := insertAsset(asset)
if err != nil {
http.Error(w, "Failed to create asset", http.StatusInternalServerError)
return
}
w.HEADer().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(map[string]int64{"id": id})
}
|
这个应用程序允许用户通过一个 REST API 端点创建新资产,并将数据存储在 PostgreSQL 数据库中。