網(wǎng)站首頁 編程語言 正文
gf gen dao
生成dao層的腳手架工具很好用,我遇到的坑是這樣的:
生成的dao文件和同事們的不一致,生成文件成功,但是對應(yīng)的Columns
是空的,雖然有這個方法,但是方法內(nèi)沒有值。我的版本比同事們的略高,我一直以為是這個原因,各種降級和同事保持一致的版本后還是不行。
最終發(fā)現(xiàn):是配置文件中連接的數(shù)據(jù)庫不對。
因為沒有連接到數(shù)據(jù)庫,所以取不到列值;但是因為配置文件中約定了表名,文件正常生成了。
好坑。
設(shè)置參數(shù)可不傳
使用 ...interface{}
func GetXxx(xxx ...interface{}) { }
model作為結(jié)構(gòu)體類型
當(dāng)我們的業(yè)務(wù)比較復(fù)雜,需要更新多個關(guān)聯(lián)表時,可以把需要修改的表統(tǒng)一定義到一個結(jié)構(gòu)體中,而不是想到一個model處理一個model。
這種思想比較好,把關(guān)聯(lián)的model統(tǒng)一封裝到一個結(jié)構(gòu)體中,很清晰,也能避免有遺漏。
type GoodsRelevantItem struct { Shop *model.Shops Brand *model.GoodsBrand Desc *model.GoodsDescription Cover []*model.GoodsCover Attributes []*model.GoodsAttributes Goods *model.Goods DisCategory []*model.DisCategory }
使用with關(guān)聯(lián)取值而不是join
能用with的一定用with關(guān)聯(lián)取值,而不是用join。
發(fā)現(xiàn)自己整理的栗子沒有官網(wǎng)的好,大家還是看官網(wǎng)吧: goframe.org/pages/viewp…
不使用結(jié)構(gòu)體批量添加數(shù)據(jù)
goframe非常靈活,插入的數(shù)據(jù)可以是結(jié)構(gòu)體也可以是map,也可以是map類型的切片,來實現(xiàn)批量添加。
主程序如下:
//主圖輪播 goodsImgs := []map[string]interface{}{} //圖片集 for k, img := range gomeGoods.MainImgs { goodsImg := map[string]interface{}{} //圖片 goodsImg["cover"] = "http:" + img goodsImg["goods_id"] = gconv.Int(goodsDetail["goods_id"]) goodsImg["sort"] = k goodsImgs = append(goodsImgs, goodsImg) } //添加主圖 err = m.AddGoodsCover(ctx, tx, goodsImgs) if err != nil { err = errors.New("添加商品主圖失敗") return err, 0 }
gomeGoods.MainImgs的定義:
MainImgs []string `json:"mainImgs"`
插入數(shù)據(jù)
batch指定了批量插入時一次插入的條數(shù)
func (m *goodsMessageService) AddGoodsCover(ctx context.Context, tx *gdb.TX, goodsImgs g.List) (err error) { if len(goodsImgs) == 0 { return errors.New("暫無數(shù)據(jù)") } _, err = dao.GoodsCover.TX(tx).Ctx(ctx).Batch(len(goodsImgs)).Insert(goodsImgs) checkErr(err, "UpdateGoodsCover") return }
原文鏈接:https://juejin.cn/post/7081959981456556068
相關(guān)推薦
- 2022-06-02 Tomcat用戶管理的優(yōu)化配置詳解_Tomcat
- 2022-07-09 document.write() 的作用*
- 2022-10-21 tomcat8中startup可以啟動tomcat8w無法啟動的問題分析_Tomcat
- 2022-06-12 python數(shù)據(jù)處理詳情_python
- 2022-09-29 React函數(shù)組件useContext?useReducer自定義hooks_React
- 2023-01-01 詳解Python如何實現(xiàn)輸出顏色字體到終端界面_python
- 2022-05-24 C#多線程TPL常見操作誤區(qū)與異常處理_C#教程
- 2023-01-15 React報錯Too?many?re-renders解決_React
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支