使用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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 手把手带你走进Go语言之常量解析

    手把手带你走进Go语言之常量解析

    这篇文章主要介绍了Go语言之常量解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • Golang通道阻塞情况与通道无阻塞实现小结

    Golang通道阻塞情况与通道无阻塞实现小结

    本文主要介绍了Golang通道阻塞情况与通道无阻塞实现小结,详细解析了通道的类型、操作方法以及垃圾回收机制,从基础概念到高级应用,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • go语言中int和byte转换方式

    go语言中int和byte转换方式

    这篇文章主要介绍了go语言中int和byte转换方式,需要的朋友可以参考下
    2018-11-11
  • Go实现并发的示例代码

    Go实现并发的示例代码

    Go语言的并发机制是其强大和流行的一个关键特性之一,本文主要介绍了Go实现并发的示例代码,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • Golang实现事务型内存数据库的方法详解

    Golang实现事务型内存数据库的方法详解

    内存数据库经我们经常用到,例如Redis,那么如何从零实现一个内存数据库呢,本文旨在介绍如何使用Golang编写一个KV内存数据库MossDB
    2023-03-03
  • 源码解析gtoken替换jwt实现sso登录

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

    这篇文章主要为大家介绍了源码解析gtoken替换jwt实现sso登录的示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • golang之反射和断言的具体使用

    golang之反射和断言的具体使用

    这篇文章主要介绍了golang之反射和断言的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Golang 如何实现函数的任意类型传参

    Golang 如何实现函数的任意类型传参

    这篇文章主要介绍了Golang 实现函数的任意类型传参操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • go面向对象方式操作JSON库实现四则运算

    go面向对象方式操作JSON库实现四则运算

    这篇文章主要为大家介绍了go面向对象方式操作JSON库实现四则运算的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Golang内存模型教科书级讲解

    Golang内存模型教科书级讲解

    go官方介绍go内存模型的时候说:探究在什么条件下,goroutine 在读取一个变量的值的时,能够看到其它 goroutine 对这个变量进行的写的结果,Go内存模型规定了一些条件,在这些条件下,在一个goroutine中读取变量返回的值能够确保是另一个goroutine中对该变量写入的值
    2023-03-03

最新评论