返回介绍

Gorm 介绍

发布于 2023-06-25 22:01:53 字数 3946 浏览 0 评论 0 收藏 0

GORM是使用Go语言开发的友好的ORM库。

1.1.1. 安装

    go get -u github.com/jinzhu/gorm

通用数据库接口sql.DB

*gorm.DB连接获取通用数据库接口*sql.DB

    // 获取通用数据库对象`*sql.DB`以使用其函数
    db.DB()

    // Ping
    db.DB().Ping()

1.1.2. 连接池

    db.DB().SetMaxIdleConns(10)
    db.DB().SetMaxOpenConns(100)

1.1.3. 复合主键

将多个字段设置为主键以启用复合主键

    type Product struct {
        ID           string `gorm:"primary_key"`
        LanguageCode string `gorm:"primary_key"`
    }

1.1.4. 日志

Gorm有内置的日志记录器支持,默认情况下,它会打印发生的错误

    // 启用Logger,显示详细日志
    db.LogMode(true)

    // 禁用日志记录器,不显示任何日志
    db.LogMode(false)

    // 调试单个操作,显示此操作的详细日志
    db.Debug().Where("name = ?", "jinzhu").First(&User{})

1.1.5. 自定义日志

参考GORM的默认记录器如何自定义它https://github.com/jinzhu/gorm/blob/master/logger.go

    db.SetLogger(gorm.Logger{revel.TRACE})
    db.SetLogger(log.New(os.Stdout, "\r\n", 0))

1.1.6. 架构

Gorm使用可链接的API,*gorm.DB是链的桥梁,对于每个链API,它将创建一个新的关系。

    db, err := gorm.Open("postgres", "user=gorm dbname=gorm sslmode=disable")

    // 创建新关系
    db = db.Where("name = ?", "jinzhu")

    // 过滤更多
    if SomeCondition {
        db = db.Where("age = ?", 20)
    } else {
        db = db.Where("age = ?", 30)
    }
    if YetAnotherCondition {
        db = db.Where("active = ?", 1)
    }

当我们开始执行任何操作时,GORM将基于当前的*gorm.DB创建一个新的*gorm.Scope实例

    // 执行查询操作
    db.First(&user)

并且基于当前操作的类型,它将调用注册的creating,updating,querying,deleting或row_querying回调来运行操作。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文