日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

golang?gorm更新日志執(zhí)行SQL示例詳解_Golang

作者:Jeff的技術(shù)棧 ? 更新時(shí)間: 2022-06-16 編程語言

1. 更新日志

1.1. v1.0

1.1.1. 破壞性變更

  • gorm.Open返回類型為*gorm.DB而不是gorm.DB
  • 更新只會(huì)更新更改的字段

大多數(shù)應(yīng)用程序不會(huì)受到影響,只有當(dāng)您更改回調(diào)中的更新值(如BeforeSaveBeforeUpdate)時(shí),應(yīng)該使用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  // 不工作,更新時(shí)不會(huì)包括EncryptedPassword字段
  }
}

軟刪除的默認(rèn)查詢作用域只會(huì)檢查deleted_at IS NULL

之前它會(huì)檢查deleted_at小于0001-01-02也排除空白時(shí)間,如:

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

但是沒有必要,如果你使用*time.Time作為模型的DeletedAt,它已經(jīng)被gorm.Model使用了,所以SQL就足夠了

SELECT * FROM users WHERE deleted_at IS NULL

所以如果你使用gorm.Model,那么你是好的,沒有什么需要改變,只要確保所有記錄的空白時(shí)間為deleted_at設(shè)置為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,F(xiàn)ield的名稱轉(zhuǎn)換為db名稱之前,只有那些來自golint的常見初始化(如HTTPURI)是特殊處理的。

所以字段HTTP的數(shù)據(jù)庫名稱將是http而不是h_t_t_p,但是一些其他的初始化,如SKU不在golint,它的數(shù)據(jù)庫名稱將是s_k_u,這看起來很丑陋,這個(gè)版本固定這個(gè),任何大寫的初始化應(yīng)該正確轉(zhuǎn)換。

錯(cuò)誤RecordNotFound已重命名為ErrRecordNotFound

mssql驅(qū)動(dòng)程序已從默認(rèn)驅(qū)動(dòng)程序中刪除,

導(dǎo)入它用import _ "github.com/jinzhu/gorm/dialects/mssql"

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

gorm執(zhí)行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

欄目分類
最近更新