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

 更新时间:2024年08月10日 11:32:17   作者:PHPz  
在go中集成postgresql需使用gorm orm,步骤如下:安装go和postgresql,安装 gorm:go get -u gorm.io/gorm,配置数据库连接字符串,定义模型类,迁移数据库架构,使用 gorm 进行增删改查操作,本指南将介绍如何使用 GORM(一个广受欢迎的 ORM),将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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 源码解析gtoken替换jwt实现sso登录

    源码解析gtoken替换jwt实现sso登录

    这篇文章主要为大家介绍了源码解析gtoken替换jwt实现sso登录的示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • 15个Golang中时间处理的实用函数

    15个Golang中时间处理的实用函数

    在Go编程中,处理日期和时间是一项常见任务,涉及到精确性和灵活性,本文将介绍一系列实用函数,它们充当time包的包装器,需要的可以参考下
    2024-01-01
  • 浅析Golang中类型嵌入的简介与使用

    浅析Golang中类型嵌入的简介与使用

    类型嵌入指的就是在一个类型的定义中嵌入了其他类型,Go 语言支持两种类型嵌入,分别是接口类型的类型嵌入和结构体类型的类型嵌入,下面我们就来详细一下类型嵌入的使用吧
    2023-11-11
  • Golang 内存模型The Go Memory Model

    Golang 内存模型The Go Memory Model

    这篇文章主要为大家介绍了Golang 内存模型The Go Memory Model实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • Golang开发中常用的代码片段汇总

    Golang开发中常用的代码片段汇总

    这篇文章主要给大家汇总了在Golang开发中常用的代码片段,这些代码片段都是在日常工作中编写golang应用时使用到,需要的朋友可以参考借鉴,下面跟着小编一起来学习学习吧。
    2017-07-07
  • 使用go gin来操作cookie的讲解

    使用go gin来操作cookie的讲解

    今天小编就为大家分享一篇关于使用go gin来操作cookie的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04
  • golang中的时间格式化

    golang中的时间格式化

    这篇文章主要介绍了golang中的时间格式化问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • golang整合jwt的实现示例

    golang整合jwt的实现示例

    json web tokens(jwt)已成为大多数web api设计中的常见身份验证和授权方案之一,本文主要介绍了golang整合jwt的实现示例,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2024-08-08
  • golang映射Map的方法步骤

    golang映射Map的方法步骤

    这篇文章主要介绍了golang映射Map的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Go语言中读取命令参数的几种方法总结

    Go语言中读取命令参数的几种方法总结

    部署golang项目时难免要通过命令行来设置一些参数,那么在golang中如何操作命令行参数呢?那么下面这篇文章就来给大家介绍了关于Go语言中读取命令参数的几种方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起看看吧。
    2017-11-11

最新评论