golang中gorm使用
2024-01-09 20:53:18
前言
记录下go语言操作mysql数据库,选用gorm,gorm是一个流行的对象关系映射(ORM)库,用于简化与数据库的交互。
接入步骤
-
安装gorm:首先,你需要使用Go模块来安装gorm。在终端中运行以下命令:
go get -u gorm.io/gorm
-
选择数据库驱动:gorm本身是一个抽象层,需要使用特定数据库的驱动程序。选择适合你数据库的驱动并安装它。例如,如果你使用MySQL,可以运行:
go get -u gorm.io/driver/mysql
如果使用其他数据库,选择对应的驱动。
-
导入gorm和数据库驱动:在go代码中导入gorm和所选的数据库驱动。
package main import ( "gorm.io/gorm" "gorm.io/driver/mysql" )
-
连接数据库:使用gorm的
Open
函数连接到数据库。在你的代码中设置数据库连接字符串。dsn := "user:password@tcp(localhost:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local" db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{}) if err != nil { panic("Failed to connect to database") }
-
定义模型:创建与数据库表对应的模型结构体。
type User struct { gorm.Model Username string Email string }
在这个例子中,
User
模型包含ID
、CreatedAt
、UpdatedAt
和DeletedAt
等gorm提供的标准模型字段。 -
迁移数据库:使用gorm的
AutoMigrate
方法创建表格。这会确保数据库中有你定义的模型对应的表格。err = db.AutoMigrate(&User{}) if err != nil { panic("Failed to migrate database") }
-
使用gorm进行CRUD操作:现在你可以使用gorm进行数据库操作,例如创建、查询、更新和删除记录。
// 创建记录 user := User{Username: "john_doe", Email: "john@example.com"} db.Create(&user) // 查询记录 var foundUser User db.First(&foundUser, "username = ?", "john_doe") // 更新记录 db.Model(&foundUser).Update("Email", "new_email@example.com") // 删除记录 db.Delete(&foundUser)
-
项目中可以参考下面代码:在model包中使用全局的db变量即可进行mysql操作
package model import ( "fmt" "log" "time" "gorm.io/driver/mysql" "gorm.io/gorm" "gorm.io/gorm/schema" ) // 创建全局数据库连接对象 var db *gorm.DB // 模型/数据库连接对象 初始化 func init() { var ( err error dbName, user, password, host string ) dbName = "" //数据库名称 user = "" //用户名 password = "" //密码 host = "" //连接地址 db, err = gorm.Open(mysql.Open(fmt.Sprintf("%s:%s@tcp(%s)/%s? charset=utf8&parseTime=True&loc=Local", user, password, host, dbName)), &gorm.Config{ NamingStrategy: schema.NamingStrategy{ SingularTable: true, }}) if err != nil { log.Println(err) } sqlDB, err := db.DB() if err != nil { log.Println(err) } sqlDB.SetMaxIdleConns(10) sqlDB.SetMaxOpenConns(100) sqlDB.SetConnMaxLifetime(time.Hour) }
这是一个基本的gorm集成和使用示例。根据你的实际需求,可能需要更复杂的查询、关联等操作,gorm提供了强大的功能来满足这些需求。可以查阅gorm文档以获取更详细的信息。
文章来源:https://blog.csdn.net/u010844836/article/details/135369564
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!