golang?gorm更新日志執(zhí)行SQL示例詳解
1. 更新日志
1.1. v1.0
1.1.1. 破壞性變更
- gorm.Open返回類型為
*gorm.DB
而不是gorm.DB
- 更新只會(huì)更新更改的字段
大多數(shù)應(yīng)用程序不會(huì)受到影響,只有當(dāng)您更改回調(diào)中的更新值(如BeforeSave
,BeforeUpdate
)時(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的常見初始化(如HTTP
,URI
)是特殊處理的。
所以字段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(&re) fmt.Println(re) for _,k :=range re{ fmt.Println(k.Uid) } }
以上就是golang gorm更新日志執(zhí)行SQL示例詳解的詳細(xì)內(nèi)容,更多關(guān)于golang gorm更新日志執(zhí)行SQL的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Go語言leetcode題解953驗(yàn)證外星語詞典示例詳解
這篇文章主要為大家介紹了Go語言leetcode題解953驗(yàn)證外星語詞典示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12在Go語言中實(shí)現(xiàn)DDD領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)實(shí)例探究
本文將詳細(xì)探討在Go項(xiàng)目中實(shí)現(xiàn)DDD的核心概念、實(shí)踐方法和實(shí)例代碼,包括定義領(lǐng)域模型、創(chuàng)建倉(cāng)庫、實(shí)現(xiàn)服務(wù)層和應(yīng)用層,旨在提供一份全面的Go DDD實(shí)施指南2024-01-01golang使用bcrypt包對(duì)密碼進(jìn)行加密的方法實(shí)現(xiàn)
本文主要介紹了golang使用bcrypt包對(duì)密碼進(jìn)行加密的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07如何判斷Golang接口是否實(shí)現(xiàn)的操作
這篇文章主要介紹了如何判斷Golang接口是否實(shí)現(xiàn)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12