Gorm的基本使用
- Gorm的约定(默认)
- Gorm使用名为ID的字段为主键
- 使用结构体的蛇形负数作为表名
- 字段名的蛇形作为列名
- 使用GreateAt, UpdateAt字段作为创建,更新时间
Gorm目前支持MySQL,SQlserver,PostgreSQL,SQlite.
Gorm通过驱动来连接数据库,如果需要连接其他类型的数据库,可以复用/自行开发驱动.
创建数据
查询数据
- First的使用踩坑
- 使用First时, 需要注意查询不到的数据会返回ErrRecordNotFound.使用Find查询多条数据, 查询不到数据不会返回错误
- 使用结构体作为查询条件
- 当使用结构体作为条件查询时, GORM只会查询非零值字段.这意味着如果您的字段值为0, "", false或其他零值,该字段不会被用于构建查询条件,使用Map来构建查询条件.
更新数据
使用Struct更新时, 只会更新非零值, 如果需要更新零值可以使用Map 更新或者使用Select选择字段.
删除数据
物理删除
软删除
GORM提供了gorm.DeletedAt用于帮助用户实现软删除. 拥有软删除能力的Model调用Delete时, 记录不会被从数据库中真正删除. 但GORM会将DeletedAt置为当前时间, 并且你不能再通过正常的查询方法找到该纪录. 使用Unscoped可以查询到被软删的数据
GORM事务
Gorm提供了Begin,Commit, Rollback 方法用于使用事务
Gorm提供了Tansaction方法用于自动提交事务,避免用户漏泄Commit, Rollback