您现在的位置是:网站首页> 编程资料编程资料
golang gorm更新日志执行SQL示例详解_Golang_
2023-05-26
388人已围观
简介 golang gorm更新日志执行SQL示例详解_Golang_
1. 更新日志
1.1. v1.0
1.1.1. 破坏性变更
- gorm.Open返回类型为
*gorm.DB而不是gorm.DB - 更新只会更新更改的字段
大多数应用程序不会受到影响,只有当您更改回调中的更新值(如BeforeSave,BeforeUpdate)时,应该使用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的常见初始化(如HTTP,URI)是特殊处理的。
所以字段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(&re) fmt.Println(re) for _,k :=range re{ fmt.Println(k.Uid) } }以上就是golang gorm更新日志执行SQL示例详解的详细内容,更多关于golang gorm更新日志执行SQL的资料请关注其它相关文章!
相关内容
- golang gorm开发架构及写插件示例_Golang_
- golang gorm错误处理事务以及日志用法示例_Golang_
- golang gorm的Callbacks事务回滚对象操作示例_Golang_
- Golang协程池gopool设计与实现_Golang_
- golang gorm的预加载及软删硬删的数据操作示例_Golang_
- golang gorm的关系关联实现示例_Golang_
- golang gorm模型结构体的定义示例_Golang_
- Go语言学习之循环语句使用详解_Golang_
- golang gorm框架数据库的连接操作示例_Golang_
- axios gin的GET和POST请求实现示例_Golang_
