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

作者:Jeff的技术栈 时间:2024-04-23 09:46:24 

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)
}
}

来源:https://www.cnblogs.com/guyouyin123/p/15770452.html

标签:golang,gorm,更新日志,执行SQL
0
投稿

猜你喜欢

  • Python入门篇之字典

    2022-09-24 23:53:47
  • python使用turtle库与random库绘制雪花

    2021-02-21 22:51:20
  • PHP 用数组降低程序的时间复杂度

    2023-10-08 11:38:03
  • oracle误删数据表还原的二种方法(oracle还原)

    2024-01-14 21:33:55
  • layer实现登录弹框,登录成功后关闭弹框并调用父窗口的例子

    2024-04-22 12:46:06
  • python记录程序运行时间的三种方法

    2023-08-25 03:12:19
  • Vue3+Vite实现动态路由的详细实例代码

    2023-07-02 16:58:37
  • python实现二叉排序树

    2022-08-26 04:34:37
  • macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16

    2023-11-15 13:05:39
  • MySql版本问题sql_mode=only_full_group_by的完美解决方案

    2024-01-18 16:08:14
  • Python笔记之facade模式

    2023-10-18 22:59:50
  • python画双y轴图像的示例代码

    2021-12-07 16:07:12
  • Python3连接MySQL(pymysql)模拟转账实现代码

    2024-01-21 09:37:45
  • Javascript 闭包[翻译]

    2008-09-28 20:59:00
  • django.db.utils.ProgrammingError: (1146, u“Table‘’ doesn’t exist”)问题的解决

    2022-01-12 14:02:31
  • MySQL性能诊断与调优工具

    2010-11-02 11:41:00
  • numpy和pandas中数组的合并、拉直和重塑实例

    2022-06-28 02:55:07
  • IDEA 2020 设置项目集成git 及svn和git之间的切换问题

    2022-11-23 20:02:14
  • HTML5 Canvas 起步(3) - 颜色与渐变

    2009-06-08 12:58:00
  • js里面的变量范围分享

    2024-04-19 09:51:47
  • asp之家 网络编程 m.aspxhome.com