介绍与使用 2.1 AutoMigrate介绍 AutoMigrate 是 Gorm 提供的一个功能强大的数据库迁移工具,它可以自动创建或更新数据库表结构,使数据库的结构与 Golang 模型一致。...查看 GORM 配置 获取详情 4.3 列名(Column Name) 根据约定,数据表的列名使用的是 struct 字段名的 蛇形命名 type User struct { ID uint...这样您就可以让一个字段的权限是只读、只写、只创建、只更新或者被忽略 注意: 使用 GORM Migrator 创建表时,不会创建被忽略的字段 type User struct { Name string...int64 `gorm:"autoCreateTime"` // 使用时间戳秒数填充创建时间 } 5.3 嵌入结构体 对于匿名字段,GORM 会将其字段包含在父结构体中,例如: type...在使用指定数据库数据类型时,它需要是完整的数据库数据类型,如:MEDIUMINT UNSIGNED not NULL AUTO_INCREMENT serializer 指定如何将数据序列化和反序列化到数据库中的序列化程序
如果约定不符合您的需求,GORM 允许您自定义配置它们,这个后面再说。...这样您就可以让一个字段的权限是只读、只写、只创建、只更新或者被忽略 注意: 使用 GORM Migrator 创建表时,不会创建被忽略的字段 type User struct { Name string...Created int64 `gorm:"autoCreateTime"` // 使用时间戳秒数填充创建时间 } ---- 嵌入结构体 对于匿名字段,GORM 会将其字段包含在父结构体中...中的tag类似java中注解的作用 标签名 说明 column 指定 db 列名 type 列数据类型,推荐使用兼容性好的通用类型,例如:所有数据库都支持 bool、int、uint、float、string...在使用指定数据库数据类型时,它需要是完整的数据库数据类型,如:MEDIUMINT UNSIGNED not NULL AUTO_INCREMENT serializer specifies serializer
钩子函数在 GORM 中,钩子函数可以在数据库操作的不同阶段执行自定义的逻辑,常见的钩子函数包括创建前钩子、更新前钩子、删除前钩子和查询后钩子。...nil}在这个示例中,我们定义了一个名为 BeforeCreate() 的方法,接收一个 *gorm.DB 类型的参数 tx,用于在创建记录之前执行自定义的逻辑。...下面是一个示例,展示了如何在 GORM 中创建迁移:import ( "gorm.io/gorm" "gorm.io/driver/mysql")type Product struct {...(&Product{})}在这个示例中,我们首先获取了一个 Migrator 对象,然后使用 AutoMigrate() 方法执行了迁移,它会根据模型结构体自动创建对应的数据库表。...()}在这个示例中,我们首先获取了一个 Migrator 对象,然后使用 Rollback() 方法回滚了最近的一个迁移操作。
由于go-zero自带的sqlx太难用, 实在无法忍受写这么多的魔法字符串, 所以这边在go-zero中引入gorm 代码 // cmd/gen.go package main import ( "...如字段`age`表默认值为10, 即使你显式设置为0最后也会被GORM设为10提交. // 如果该字段没有上面提到的插入时赋零值的特殊需要, 则字段为非指针类型使用起来会比较方便....; // 自动时间戳默认字段名为:`updated_at`、`created_at, 表字段数据类型为: INT 或 DATETIME // 软删除默认字段名为:`deleted_at`, 表字段数据类型为...目录; 先创建结果不会被后创建的覆盖 g.ApplyBasic(allModel...)...entity是gorm model代码 cmd下的gen.go是gorm gen的配置 pkg下的gorm.go是自定义日志驱动以及配置连接池 +---app | +---account |
) // INSERT INTO `users` (`name`,`age`,`created_at`) VALUES ("大忽悠", 18, "2022-08-04 11:05:21.775") 创建一个记录且一同忽略传递给略去的字段值...创建记录时将调用这些钩子方法,请参考 Hooks 中关于生命周期的详细信息 钩子方法常与模板方法模式搭配使用,通常暴露给用户自定义相关组件,以此提高框架整体可扩展性 func (u *User)...根据 map[string]interface{} 或 自定义数据类型 创建,例如: // 通过 map 创建记录 DB.Model(User{}).Create(map[string]interface...(UPPER('dhy'),18) 通过自定义类型创建记录: // 通过自定义类型创建记录 type Location struct { X, Y int } // Scan 方法实现了 sql.Scanner...} Gorm操作对象属性前,会先去寻找Scan和Value方法,如果有则调用,这一点类似Java中操作对象属性通常使用Getter和Setter方法一般。
结构体标签定义通过 reflect.Type 获取结构体成员信息 reflect.StructField 结构中的 Tag 被称为结构体标签(Struct Tag)。...标签模型是标准的 struct,由基本数据类型以及实现了 Scanner 和 Valuer 接口的自定义类型及其指针或别名组成。...在使用指定数据库数据类型时,它需要是完整的数据库数据类型,如:MEDIUMINT UNSIGNED not NULL AUTO_INCREMENTsize指定列大小,例如:size:256primaryKey...,查看 索引 获取详情uniqueIndex与 index 相同,但创建的是唯一索引check创建检查约束,例如 check:age > 13,查看 约束 获取详情<-设置字段写入的权限, <-:create...3gte参数值大于等于给定值binding:"gte=3"大于等于3lt参数值小于给定值binding:"lt=3"小于3gt参数值大于给定值binding:"gt=3"大于3oneof参数值只能是枚举值中的一个
根据 map[string]interface{} 或 自定义数据类型 创建,例如: // 通过 map 创建记录 db.Model(User{}).Create(map[string]interface...`id` LIMIT 1 查看 原生 SQL 及构造器 获取详情 3.8 Find 至 map GORM 允许扫描结果至 map[string]interface{} 或 []map[string]interface...`deleted_at` IS NULL 并且 GORM 也允许使用 SQL 表达式、自定义数据类型的 Context Valuer 来更新,例如: // 根据自定义数据类型创建 type Location...rows.Next() { rows.Scan(&name, &age) fmt.Printf("name是:%s,age是:%d\n",name,age) } 转到 FindInBatches 获取如何在批量中查询和处理记录的信息..., 转到 Group 条件 获取如何构建复杂 SQL 查询的信息 8.6 将 sql.Rows 扫描至 model 使用 ScanRows 将一行记录扫描至 struct,例如: rows, err :
01 概念 在项目开发中,数据库写操作包含新增、删除和修改,使用 GORM V2 可以更加安全和便捷进行写操作。...02 新增 普通创建 使用 GORM V2 创建记录,可以定义一个自定义结构体类型的变量,调用 Create 方法,通过入参结构体类型变量的指针来创建记录。...", "Email").Create(&stu) 批量创建 定义一个切片变量,通过调用 Create 方法,入参切片类型的变量,GORM 会生成一个单一的 sql 语句来插入所有数据,并回填主键的值。...默认值 可以使用 GORM 标签 default 设置默认值,插入数据时,设置的默认值会被用于填充值为零值的字段。 需要注意的是,如果默认值本身是数据类型的零值,将不会被保存到数据库。...stu := Student{} stu.ID = 16 gormDB.Delete(&stu) 根据主键删除 GORM 支持根据内联条件指定删除对象的主键,但是只支持数据类型为整型主键。
2.3 查询方法 gorm.DB 提供了多种查询方法,如 Find、First、Where、Order 等,用于执行不同类型的数据库查询操作。...自定义数据类型 gorm.DB 允许你定义和使用自定义数据类型,以便更好地映射数据库中的数据。...New Session Method 用于新建会话,相当于创建了一个 gorm.DB 对象。 上面三种方法都会返回一个新的 gorm.DB 对象。...Chain Method 的第一句都会调用 getInstance 克隆当前 gorm.DB 对象获取一个新的 gorm.DB 对象。...在 gorm.DB 对象的链式调用过程中,会基于全局 gorm.DB 对象克隆一个新的 gorm.DB 对象,使得每次执行不同的 SQL 相互隔离、互补干扰。
0}func (m *User) GetName() string { if m == nil || m.Name == nil { return "" } return *m.Name}自定义表名称当从数据库生成结构时...gen.WithMethod(gen.DefaultMethodTableWithNamer))Field Options以下是可以在生成模型/生成模型期间使用的选项FieldNew // 创建一个新字段...gen.NewGenerator(gen.Config{ // 如果希望可为空字段生成属性为指针类型,请将 FieldNullable 设置为 true FieldNullable: true, // 如果要分配在“创建...true, // if you need unit tests for query code, set WithUnitTest true WithUnitTest: true,})// 设置获取数据库名称函数...(paths ...string)// 指定全局模型选项WithOpts(opts ...ModelOpt)数据类型映射指定model属性类型和 db 字段类型之间的映射关系。
尽量遵循 GORM 已有的约定,但是如果约定不符合需求,也可以自定义配置,从而改变已有约定,达到满足需求的目的。...02 模型定义 与使用 Go 标准库 sql 包操作数据库表相同,使用 GORM 操作数据库,也需要先声明模型,模型一般是基于 Go 语言的基础数据类型、实现了 Scanner 和 Valuer 接口的自定义类型...gorm.Model GORM 定义了一个 gorm.Model 结构体,字段包括 ID、CreatedAt、UpdatedAt、DeletedAt,我们可以将它嵌入到我们自定义的结构体中,详情见 04...使用可导出的字段进行 CRUD 时拥有全部权限,另外,GORM 可以使用标签控制字段级别的权限,可以让一个字段的权限是只读、只写、只创建、只更新和忽略该字段。...我们会在后续章节中,陆续使用到 GORM 提供的字段标签。
Gorm是一种流行的Go编程语言的ORM(对象关系映射)库,它为开发人员提供了一种简便的方式来管理数据库,并将对象模型映射到关系型数据库中。Gorm的特点1....提供强大的查询功能Gorm提供了许多强大的查询功能,如条件查询、排序、分组、连接查询和原始SQL查询等。这些功能使得开发人员可以轻松地执行复杂的数据库查询操作。3....支持事务处理Gorm支持事务处理,这意味着开发人员可以将一系列数据库操作放在同一个事务中,并且在任何一个操作失败时,事务会自动回滚,保证数据的完整性。4....可扩展性强Gorm的可扩展性非常强,可以通过插件机制来扩展其功能。例如,可以通过插件来添加缓存、日志记录和自定义数据类型等功能。Gorm的优势1....灵活可配置Gorm提供了许多配置选项,可以根据需要进行自定义配置。例如,可以配置数据库连接池大小、日志级别、默认表名前缀等。4.
可以通过标签自定义字段对应的列名。...使用AssociationForeignKey标签自定义关联外键,foreignkey标签自定义外键。 User属于Profile,ProfileID为外键。...(&user).Related(&profile) 一对一 User包含一个CreditCard,UserID为外键。...,按主键排序 db.First(&user) // 获取最后一条记录,按主键排序 db.Last(&user) // 获取所有记录 db.Find(&users) // 使用主键获取记录 db.First...那么在调用Delete时不会从数据库中永久删除,而是只将字段DeletedAt的值设置为当前时间。
V2 支持在日志中增加追踪信息 说实话这个是我选择升级到V2的一个主要原因, 良好的基础框架是一个项目成功的必备因素,GORM V1版本开发的Logger接口中我们是没有办法把请求上下文传递进去的。...在使用GORM的时候,如果我们想把GORM产生的日志记录到项目统一的应用日志中的时,需要自己去实现GORM提供的logger 接口。...当我们自己实现好GORM的Logger后,在GORM创建连接的时候需要把Logger选项配置成我们自定义Logger db, err := gorm.Open( mysql.Open(...接下来说下第二个让我决定使用GORM V2 的原因 CREATE方法支持批量创建模型 在GORM V1版本里,模型本身是不在带批量创建的功能的,想要批量创建一种选择是写个循环,在循环里调用模型的Create...还有一种是使用db.Raw 或者 db.Exec 执行手写的SQL来进行批量创建,我以前每次需要批量创建模型是都会手动在模型里定义一个BulkCreate方法 func BulkInsertOrderGoods
ORM,即对象关系映射(Object Relational Mapping),可以简单理解为将关系型数据库中的数据表映射为编程语言中的具体的数据类型(如struct),而GORM库就是一个使用Go语言实现的且功能非常完善易使用的...数据库自动迁移 自定义日志 可扩展性, 可基于 GORM 回调编写插件 如何安装 安装GORM非常简单,使用go get -u就可以在GOPATH目录下安装最新GROM框架。...基本操作 使用gorm.Open()函数返回一个gorm.DB结构体后,我们可以使用gorm.DB结构体提供的方法操作数据库,下面我们演示如何使用gorm.DB进行创建、查询、更新、删除等最基本的操作。...结构体中的DB()方法,可以返回一个sql.DB对象,如下: func (s *DB) DB() *sql.DB 下面演示的是使用gorm.DB结构体中一些更简便的方法进行数据库基本操作,不过,在演示之前...创建 使用gorm.DB中的Create()方法,GORM会根据传给Create()方法的模型,向数据表插入一行。
,如拼接SQL、数据解析,所以就有了ORM这个概念 - 将内存中的数据结构(对象)与数据库中的表对应起来。...以GORM字段权限控制为例: type User struct { Name string `gorm:"<-:create"` // 允许读和创建 Name string `gorm:"<-:...// 允许读,禁止写 Name string `gorm:"->"` // 只读(除非有自定义配置,否则禁止写) Name string `gorm:"->;<-:create"`...我举两个反例: 字段默认值有特殊的含义,如建表时status的默认值设置为100 改进方案:如果100这个值有业务含义,应在Go程序中设置 表中增加Trigger,如status字段修改为某个值后,自动触发另一个字段的修改...由于MySQL中的数据类型更为复杂,可以维护一个从 解析建表语句,自动生成Go中ORM结构体 的代码生成工具。
,而是deleted_at 会更新删除时间 db.Delete(&uu) } 使用gorm必须要先创建好数据库 gorm会自动创建数据表,且表结构可以动态变化 gorm创建的表命名方式为 代码中结构体命名的转换..., 例如 结构体命名为UserInfo,则table会命名为user_infos gorm修改表结构非常的容易 gorm是完全面向对象的思想 3 模型定义 模型是标准的 struct,由 Go 的基本数据类型...`gorm:"index:addr"` // 给address字段创建名为addr的索引 IgnoreMe int `gorm:"-"`...将切片数据传递给 Create 方法,GORM 将生成一个单一的 SQL 语句来插入所有数据,并回填主键的值,钩子方法也会被调用。...(users, 100) 默认值 您可以通过标签 default 为字段定义默认值,如: type User struct { ID int64 Name string `gorm:"default
数据类型使用 size:n 标签映射; 字符串类型主键字段的 GORM 数据类型使用 type:varchar(n) 标签映射; ID 字段在 GORM 中默认为主键,两个字母全部大写,建议显式指定...整数类型字段映射 Go 整数类型字段 GORM 数据类型使用 size:n(n 为字段大小,如 size:64)标签映射, GORM 会根据 Go 类型和 size 自动转换为对应的数据库类型,通过...浮点类型字段映射 Go 浮点类型字段 GORM 数据类型使用 precision:n(n 为精度,如 precision:18)和 scale:n(n 为小数位数,如 scale:4 )标签映射,...字符串类型字段映射 Go 字符串类型字段 GORM 数据类型建议使用 size:n(n 为字段大小,如 size:1000)标签映射, GORM 会根据 Go 类型和 size 自动转换为对应的数据库类型...Go 字节切片类型映射数据库中的二进制数据类型对照关系如下所示: 序号 数据库类型 对应二进制数据类型 1. SQL Server varbinary(MAX) 2.
今天我们来深入理解下在gorm中,Find函数的底层逻辑。 Find函数是用来从数据库中查询的。...从数据类型来看,是interface{},即可以是任意的数据类型。 用map来接收查询结果 在使用map接收查询结果时,就必须要明确地指定要查询的表了。...那这又是为什么Find的第一个参数是对应Model类型的变量时就可以不指定表名,而是map类型时就需要明确指定表名呢? 原因在于,gorm在执行具体的查询的时候,是从指定的Model对象中来解析表的。...下面是gorm中db相关的数据结构。如下: 大家看,在Statement结构中,实际上有两个字段,一个是Dest,即Find查询函数中的第一个参数,用来接收查询结果用的。...如果从Model中解析不到对应的表名,就会报错。最后,我们分析了Find函数查询一行和多行数据的区别。其本质上是扫描符合条件的所有数据,最后根据是否是切片类型来返回数据而已。
使用cli的方式启动项目的好处显而易见,可以在进行配置的自定义化,而不是固定的使用某个配置文件中的信息。在一些需要频繁更换命令参数的场景下尤为有效。...,然后使用自定义的Init***函数初使化类 ---- /tools/config文件夹中定义实体类,对应config.yml中的分类 举例:application.go对应图二的application.../v3作为casbin的数据库适配器即可 数据库上下文集成gin gin一次请求共用一个数据库实例 r.Use()是gin的中间件扩展方法,WithContextDb方法说明的是,如果每次请求到来会打开一次数据库链接...如果有此实例,c.Set()方法执行,将此实例保存到gin执行上下文中。 全局异常处理 使用一个异常捕获方法recover()补获未知晓的异常 如果异常消息符合定义的规则,打印后返回给前台。...default: panic(err) } } }() c.Next() } web服务运行区分ssl和正常 从配置文件中获取内容
领取专属 10元无门槛券
手把手带您无忧上云