今天遇到個(gè)問(wèn)題,goxorm無(wú)法更新某一個(gè)字段為0.
xxTable := models.XXTable{Visible: visible}
affected, err := eng.Where("id=?", id).Update(xxTable)
這種情況下,因?yàn)間o的結(jié)構(gòu)初始值都是各自的0值,所以xorm無(wú)法識(shí)別要更新結(jié)構(gòu)體中的哪個(gè)col,如下方法寫(xiě)可以正常解決。
xxTable := models.XXTable{Visible: visible}
affected, err := eng.Where("id=?", id).Cols("visible").Update(xxTable)
補(bǔ)充:golang gin xorm注意事項(xiàng)
1. 無(wú)論是golang還是xorm中,在填寫(xiě)j'son字段時(shí),注意空格,比如 `json:"abcd "` `json:"abcd"`是不一樣的,不仔細(xì)對(duì)比會(huì)出錯(cuò)
2.當(dāng)結(jié)合gin框中的
c.JSON(http.StatusOK,gin.H{})操作
并且使用xorm中的join,find操作時(shí)(https://www.kancloud.cn/xormplus/xorm/167102)要注意如下現(xiàn)象,
假如定義兩個(gè)結(jié)構(gòu)體對(duì)應(yīng)兩個(gè)表

然后使用聯(lián)合查詢,先把兩個(gè)結(jié)構(gòu)體結(jié)合成一個(gè)結(jié)構(gòu)體,假如如下,在UserGroup中使用User和Group匿名結(jié)構(gòu)體,

那么當(dāng)我們使用gin的c.JSON(http.StatusOK,gin.H{"data":UserGroup})返回?cái)?shù)據(jù)時(shí)會(huì)導(dǎo)致Group和User中同名字段顯示不了,這應(yīng)該是gin和xorm的不是很兼容造成的(沒(méi)有深究),要解決這個(gè)問(wèn)題,最好讓UserGroup中的User和Group不要以匿名結(jié)構(gòu)體的形式存在,可以改成
type UserGroup struct {
MyUser User `xorm:"extends" json:"你要json中返回的名字"`
MyGroup Group `xorm:"extends" json:"你要json中返回的名字"`
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- 在golang xorm中使用postgresql的json,array類型的操作
- golang xorm及time.Time自定義解決json日期格式的問(wèn)題
- golang xorm日志寫(xiě)入文件中的操作
- go語(yǔ)言 xorm框架 postgresql 的用法及詳細(xì)注解
- golang中xorm的基本使用說(shuō)明
- xorm根據(jù)數(shù)據(jù)庫(kù)生成go model文件的操作
- 使用go xorm來(lái)操作mysql的方法實(shí)例
- go xorm框架的使用