golang?gorm更新日志執(zhí)行SQL示例詳解
1. 更新日志
1.1. v1.0
1.1.1. 破壞性變更
- gorm.Open返回類型為
*gorm.DB
而不是gorm.DB
- 更新只會更新更改的字段
大多數(shù)應用程序不會受到影響,只有當您更改回調(diào)中的更新值(如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
,它已經(jīng)被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,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
,這看起來很丑陋,這個版本固定這個,任何大寫的初始化應該正確轉(zhuǎn)換。
錯誤RecordNotFound
已重命名為ErrRecordNotFound
mssql
驅(qū)動程序已從默認驅(qū)動程序中刪除,
導入它用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示例詳解的詳細內(nèi)容,更多關(guān)于golang gorm更新日志執(zhí)行SQL的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
在Go語言中實現(xiàn)DDD領(lǐng)域驅(qū)動設計實例探究
本文將詳細探討在Go項目中實現(xiàn)DDD的核心概念、實踐方法和實例代碼,包括定義領(lǐng)域模型、創(chuàng)建倉庫、實現(xiàn)服務層和應用層,旨在提供一份全面的Go DDD實施指南2024-01-01golang使用bcrypt包對密碼進行加密的方法實現(xiàn)
本文主要介紹了golang使用bcrypt包對密碼進行加密的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07