通过实战总结的GoFrame使用小技巧

gf gen dao

生成dao层的脚手架工具很好用,我遇到的坑是这样的:

创新互联建站服务项目包括钦州网站建设、钦州网站制作、钦州网页制作以及钦州网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,钦州网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到钦州省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

生成的dao文件和同事们的不一致,生成文件成功,但是对应的Columns方法是空的。虽然有这个方法,但是方法内没有值。我的版本比同事们的略高,我一直以为是这个原因,各种降级和同事保持一致的版本后还是不行。

最终发现:是配置文件中连接的数据库不对。

因为没有连接到数据库,所以取不到列值;但是因为配置文件中约定了表名,文件正常生成了。

如果你也遇到了类似问题,去排查一下配置文件吧。

设置参数可传可不传

这个场景和是否使用GoFrame框架没关系,如果你也需要设置这个参数可传可不传,也能这么搞:

使用 ...interface{}

比如:

func GetXxx(xxx ...interface{}) { }

model作为结构体类型

当我们的业务比较复杂,需要更新多个关联表时,可以把需要修改的表统一定义到一个结构体中,而不是想到一个model处理一个model。

这种思想比较好,把关联的model统一封装到一个结构体中,很清晰,也能避免有遗漏。

type GoodsRelevantItem struct {
Shop *model.Shops
Brand *model.GoodsBrand
Desc *model.GoodsDescription
Cover []*model.GoodsCover
Attributes []*model.GoodsAttributes
Goods *model.Goods
DisCategory []*model.DisCategory
}

模型关联

关于模型关联,官方是这么说的:

GoFrame的ORM没有采用其他ORM常见的BelongsTo, HasOne, HasMany, ManyToMany这样的模型关联设计,这样的关联关系维护较繁琐,例如外键约束、额外的标签备注等,对开发者有一定的心智负担。因此gf框架不倾向于通过向模型结构体中注入过多复杂的标签内容、关联属性或方法,并一如既往地尝试着简化设计,目标是使得模型关联查询尽可能得易于理解、使用便捷。

我也花时间整理了自己在项目中的示例,但是发现自己整理的例子没有官网的好理解,所以最终我还是把自己的例子删掉了。

「模型关联」这部分比较硬核且实用,但是也确实有理解成本。

大家还是看官方示例吧:

「模型关联-动态关联-ScanList」

「模型关联-静态关联-With特性」

我也会把官方示例放到阅读原文中,方便大家去查看。

添加数据

goframe非常灵活,插入的数据可以是结构体也可以是map,也可以是map类型的切片,来实现批量添加。

举个栗子:

主程序如下:

//主图轮播
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
}

MainImgs的定义:

MainImgs []string `json:"mainImgs"`

批量插入数据

batch指定了批量插入时一次插入的条数

func (m *goodsMessageService) AddGoodsCover(ctx context.Context, tx *gdb.TX, goodsImgs g.List) (err error) {
if len(goodsImgs) == 0 {
return errors.New("暂无数据")
}
_, err = dao.GoodsCover.TX(tx).Ctx(ctx).Batch(len(goodsImgs)).Insert(goodsImgs)
checkErr(err, "UpdateGoodsCover")
return
}

配置插件自动生成service

如果你在用goframe V2.1 以上版本,生成service强烈建议配置goland插件,而不是每次修改logic后手动敲脚本。

配置方式如下:

配置文件xml

小技巧:当自动生成的文件报错,或者出现一些“神奇的问题”,建议把生成的文件删除掉。在对应的logic代码空白处随便敲个回车或者空格就能生成新的service文件。

注意:千万不要手动修改自动生成的代码。(因为自己修改的代码后期肯定会被覆盖掉)

总结

纸上得来终觉浅,觉知此事要躬行。

编程是一门手艺活,一定多动手,重实践,才能获得长足的进步。

本文转载自微信公众号「 程序员升级打怪之旅」,作者「王中阳Go」,可以通过以下二维码关注。

转载本文请联系「 程序员升级打怪之旅」公众号。

本文名称:通过实战总结的GoFrame使用小技巧
文章起源:http://www.36103.cn/qtweb/news13/7563.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联