golang gorm更新日志执行SQL示例详解

2022-10-13,

这篇文章主要为大家介绍了golang gorm更新日志执行SQL示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪

目录
  • 1. 更新日志
    • 1.1. v1.0
      • 1.1.1. 破坏性变更
  • gorm执行sql

    1. 更新日志

    1.1. v1.0

    1.1.1. 破坏性变更

    • gorm.Open返回类型为*gorm.DB而不是gorm.DB
    • 更新只会更新更改的字段

    大多数应用程序不会受到影响,只有当您更改回调中的更新值(如BeforeSaveBeforeUpdate)时,应该使用scope.SetColumn,例如:

    func (user *User) BeforeUpdate(scope *gorm.Scope) {
      if pw, err := bcrypt.GenerateFromPassword(user.Password, 0); err == nil {
        scope.SetColumn("EncryptedPassword", pw)
        // user.EncryptedPassword = pw  // 不工作,更新时不会包括EncryptedPassword字段
      }
    }
    

    软删除的默认查询作用域只会检查deleted_at IS NULL

    之前它会检查deleted_at小于0001-01-02也排除空白时间,如:

    SELECT * FROM users WHERE deleted_at IS NULL OR deleted_at <= '0001-01-02'
    

    但是没有必要,如果你使用*time.Time作为模型的DeletedAt,它已经被gorm.Model使用了,所以SQL就足够了

    SELECT * FROM users WHERE deleted_at IS NULL
    

    所以如果你使用gorm.Model,那么你是好的,没有什么需要改变,只要确保所有记录的空白时间为deleted_at设置为NULL,示例迁移脚本:

    import (
        "github.com/jinzhu/now"
    )
    func main() {
      var models = []interface{}{&User{}, &Image{}}
      for _, model := range models {
        db.Unscoped().Model(model).Where("deleted_at < ?", now.MustParse("0001-01-02")).Update("deleted_at", gorm.Expr("NULL"))
      }
    }
    
    • 新的ToDBName逻辑

    在GORM将struct,Field的名称转换为db名称之前,只有那些来自golint的常见初始化(如HTTPURI)是特殊处理的。

    所以字段HTTP的数据库名称将是http而不是h_t_t_p,但是一些其他的初始化,如SKU不在golint,它的数据库名称将是s_k_u,这看起来很丑陋,这个版本固定这个,任何大写的初始化应该正确转换。

    错误RecordNotFound已重命名为ErrRecordNotFound

    mssql驱动程序已从默认驱动程序中删除,

    导入它用import _ "github.com/jinzhu/gorm/dialects/mssql"

    Hstore已移至github.com/jinzhu/gorm/dialects/postgres

    gorm执行sql

    type Object interface {
      GroupOrderOpenlog() (uidList []int)
    }
    func (o *object) GroupOrderOpenlog() {
    	type res struct {
    		Uid int `json:"uid"`
    	}
    	var re []res
    	sql:= "SELECT uid FROM order_openlog  GROUP BY uid"
    	o.Db.Raw(sql).Scan(&amp;re)
    	fmt.Println(re)
    	for _,k :=range re{
    		fmt.Println(k.Uid)
    	}
    }

    以上就是golang gorm更新日志执行SQL示例详解的详细内容,更多关于golang gorm更新日志执行SQL的资料请关注北冥有鱼其它相关文章!

    您可能感兴趣的文章:

    • golang gorm错误处理事务以及日志用法示例
    • golang gorm的Callbacks事务回滚对象操作示例
    • golang gorm框架数据库的连接操作示例
    • gorm整合进go-zero的实现方法
    • gorm+gin实现restful分页接口的实践
    • Go GORM版本2.0新特性介绍

    《golang gorm更新日志执行SQL示例详解.doc》

    下载本文的Word格式文档,以方便收藏与打印。