在 go 中集成 postgresql 需使用 gorm orm。步骤如下:安装 go 和 postgresql。安装 gorm:go get -u gorm.io/gorm。配置数据库连接字符串。定义模型类。迁移数据库架构。使用 gorm 进行增删改查操作。
在 go 应用中使用 postgresql 数据库是一种常见的需求。本指南将介绍如何使用 gorm(一个广受欢迎的 orm),将 postgresql 集成到你的 go 应用中。
先决条件
- 安装 go 1.16 或更高版本
- 安装 postgresql
gorm 安装
go get -u gorm.io/gorm
连接到 postgresql
首先,你需要配置一个数据库连接字符串,该字符串指定了你的 postgresql 数据库的信息:
import (
"fmt"
"log"
"gorm.io/driver/postgres"
"gorm.io/gorm"
)
const (
host = "localhost"
port = 5432
user = "postgres"
password = "mypassword"
dbname = "mydb"
)
dsn := fmt.sprintf("host=%s port=%d user=%s password=%s dbname=%s", host, port, user, password, dbname)
db, err := gorm.open(postgres.open(dsn), &gorm.config{})
if err != nil {
log.fatal(err)
}创建模型
接下来,你需要定义一个模型,它代表你的数据库表:
type user struct {
gorm.model
name string
email string
}迁移数据库
在向数据库中插入数据之前,你需要迁移数据库架构:
err = db.automigrate(&user{})
if err != nil {
log.fatal(err)
}增删改查操作
现在你可以开始对数据库进行增删改查操作了:
创建(create):
user := &user{name: "john doe", email: "john.doe@example.com"} db.create(user)读取(read):
users := &[]user{} db.find(users)更新(update):
db.model(&user).updates(user{email: "new.email@example.com"})删除(delete):
db.delete(&user)
实战案例
让我们创建一个简单的 api,使用 gorm 和 postgresql 来管理用户:
func main() {
// 初始化数据库连接
db := initdb()
// 迁移数据库架构
err := db.automigrate(&user{})
if err != nil {
log.fatal(err)
}
r := mux.newrouter()
r.handlefunc("/users", handleusers).methods(http.methodget, http.methodpost)
r.handlefunc("/users/{id}", handleuser).methods(http.methodget, http.methodput, http.methoddelete)
log.fatal(http.listenandserve(":8080", r))
}
func initdb() *gorm.db {
dsn := "user=postgres dbname=mydb password=mypassword sslmode=disable"
db, err := gorm.open(postgres.open(dsn), &gorm.config{})
if err != nil {
log.fatal(err)
}
return db
}这个 api 提供了以下端点:
- /users:获取所有用户(get),创建新用户(post)
- /users/{id}:获取指定用户(get),更新指定用户(put),删除指定用户(delete)
到此这篇关于使用gorm将postgresql集成到go框架中的文章就介绍到这了,更多相关gorm在go中集成postgresql内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论