Loading

如何在GORM GEN 中使用JSON Array(JSON_CONTAINS)

点开GORM GEN的官方文档,发现文档中对于JSON Query的描述就一句话

image-20230216110017914

我起初还以为是GEN不够发达,所以没实现JSON Array跟JSON Set

但是在GORM的文档中却存在对于JSON的SET与Array的描述,说这些自定义数据类型定义在https://github.com/go-gorm/datatypes下。

image-20230216111141980

我们知道GORM GEN其实就是对GORM封了一层而已,也就是说,既然GORM能有JSON Array那么GORM GEN必然也是能有的。

于是我们先学GORM GEN给出的JSON Query的例子。


点开JSONQuery结构体,我们发现这个结构体的定义正好就是在go-gorm/datatypes下:

image-20230216111006829

也就是我们想要的JSONArray所在的地方,但是发现这个库文件并没有我们想要的JSONArray。最后发现原来是因为我的go.mod设置的gorm.io/datatypes版本不够,于是就去go.mod里面改:

image-20230216111355215

之后go mod tidy一下就行了


然后我们就发现datatypes下有了JSONArray!

image-20230216111850259

然后浅浅地调用一下就行了~

query.X.Where(gen.Cond(datatypes.JSONArrayQuery("column_name").Contains("element"))...).Find()


完结撒花!

posted @ 2023-02-16 11:22  ViKyanite  阅读(780)  评论(0编辑  收藏  举报