返回顶部
首页 > 资讯 > 后端开发 > GO >golang gorm更新日志执行SQL的方法
  • 610
分享到

golang gorm更新日志执行SQL的方法

2023-06-30 03:06:20 610人浏览 八月长安
摘要

这篇文章主要介绍了golang gORM更新日志执行sql的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Golang gorm更新日志执行SQL的方法文章都会有所收获,下面我们一起来看

这篇文章主要介绍了golang gORM更新日志执行sql的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Golang 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 []ressql:= "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的方法”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网GO频道。

您可能感兴趣的文档:

--结束END--

本文标题: golang gorm更新日志执行SQL的方法

本文链接: https://lsjlt.com/news/327277.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作