網站首頁 編程語言 正文
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執行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) } }
原文鏈接:https://www.cnblogs.com/guyouyin123/p/15770452.html
相關推薦
- 2022-10-15 python-yml文件讀寫與xml文件讀寫_python
- 2021-12-03 Android識別NFC芯片制造商的方法_Android
- 2022-08-02 Python?的矩陣傳播機制Broadcasting和矩陣運算_python
- 2022-05-10 gin實現限流中間件
- 2022-11-25 ASP.NET?MVC使用異步Action的方法_實用技巧
- 2022-07-21 python logging模塊使用介紹
- 2022-09-12 詳解APScheduler如何設置任務不并發_python
- 2022-08-31 pandas基礎?Series與Dataframe與numpy對二進制文件輸入輸出_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支