GO语言框架学习day5

59 阅读1分钟

Gorm的基本使用

image.png

  • Gorm的约定(默认)
    • Gorm使用名为ID的字段为主键
    • 使用结构体的蛇形负数作为表名
    • 字段名的蛇形作为列名
    • 使用GreateAt, UpdateAt字段作为创建,更新时间

Gorm目前支持MySQL,SQlserver,PostgreSQL,SQlite.

Gorm通过驱动来连接数据库,如果需要连接其他类型的数据库,可以复用/自行开发驱动.

创建数据

查询数据

image.png

  • First的使用踩坑
    • 使用First时, 需要注意查询不到的数据会返回ErrRecordNotFound.使用Find查询多条数据, 查询不到数据不会返回错误
  • 使用结构体作为查询条件
    • 当使用结构体作为条件查询时, GORM只会查询非零值字段.这意味着如果您的字段值为0, "", false或其他零值,该字段不会被用于构建查询条件,使用Map来构建查询条件.

更新数据

image.png 使用Struct更新时, 只会更新非零值, 如果需要更新零值可以使用Map 更新或者使用Select选择字段.

删除数据

物理删除

image.png

软删除

image.png

GORM提供了gorm.DeletedAt用于帮助用户实现软删除. 拥有软删除能力的Model调用Delete时, 记录不会被从数据库中真正删除. 但GORM会将DeletedAt置为当前时间, 并且你不能再通过正常的查询方法找到该纪录. 使用Unscoped可以查询到被软删的数据

GORM事务

Gorm提供了Begin,Commit, Rollback 方法用于使用事务

image.png

Gorm提供了Tansaction方法用于自动提交事务,避免用户漏泄Commit, Rollback

image.png