golang?gorm更新日志執(zhí)行SQL示例詳解
1. 更新日志
1.1. v1.0
1.1.1. 破壞性變更
- gorm.Open返回類型為
*gorm.DB而不是gorm.DB - 更新只會更新更改的字段
大多數應用程序不會受到影響,只有當您更改回調中的更新值(如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,它已經被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的常見初始化(如HTTP,URI)是特殊處理的。
所以字段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執(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示例詳解的詳細內容,更多關于golang gorm更新日志執(zhí)行SQL的資料請關注腳本之家其它相關文章!

