目录
- 先决条件
- GORM 安装
- 连接到 PostgreSQL
- 创建模型
- 迁移数据库
- 增删改查操作
- 实战案例
在 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内容请搜索编程网(www.lsjlt.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.lsjlt.com)!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容猜你喜欢
AI推送时光机使用GORM将PostgreSQL集成到Go框架中
数据库2024-08-10Nest框架中集成使用Swagger示例说明
数据库2022-11-13GO框架中如何使用二维码生成器?
数据库2023-06-22PHP 中哪些 NPM 框架可以与 Shell 集成使用?
数据库2023-08-30GO语言学习笔记:如何将Laravel框架应用到您的GO项目中?
数据库2023-10-24如何在Spring框架中使用Go语言生成实时二维码?
数据库2023-10-26咦!没有更多了?去看看其它编程学习网 内容吧