我的编程空间,编程开发者的网络收藏夹
学习永远不晚

使用GORM将PostgreSQL集成到Go框架中

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

使用GORM将PostgreSQL集成到Go框架中

在 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

使用GORM将PostgreSQL集成到Go框架中

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

使用GORM将PostgreSQL集成到Go框架中

目录先决条件GORM 安装连接到 PostgreSQL创建模型迁移数据库增删改查操作实战案例在 go 中集成 postgresql 需使用 gorm orm。步骤如下:安装 go 和 postgresql。安装 gorm:go get -u
使用GORM将PostgreSQL集成到Go框架中
2024-08-10

Nest框架中集成使用Swagger示例说明

这篇文章主要为大家介绍了Nest框架中集成使用Swagger的示例说明,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

如何使用 Go 客户端将本地文件复制到 minikube 集群中的 pod 容器?

问题内容我的查询与标题差不多,我有一个本地文件 file.txt ,我想将其复制到 pod1 的容器 container1 中。如果我使用 kubectl 来执行此操作,适当的命令是:kubectl cp file.txt pod1:
如何使用 Go 客户端将本地文件复制到 minikube 集群中的 pod 容器?
2024-02-06

编程热搜

目录