点开GORM GEN的官方文档,发现文档中对于JSON Query的描述就一句话
我起初还以为是GEN不够发达,所以没实现JSON Array跟JSON Set
但是在GORM的文档中却存在对于JSON的SET与Array的描述,说这些自定义数据类型定义在https://github.com/go-gorm/datatypes下。
我们知道GORM GEN其实就是对GORM封了一层而已,也就是说,既然GORM能有JSON Array那么GORM GEN必然也是能有的。
于是我们先学GORM GEN给出的JSON Query的例子。
点开JSONQuery结构体,我们发现这个结构体的定义正好就是在go-gorm/datatypes下:
也就是我们想要的JSONArray所在的地方,但是发现这个库文件并没有我们想要的JSONArray。最后发现原来是因为我的go.mod设置的gorm.io/datatypes
版本不够,于是就去go.mod里面改:
之后go mod tidy
一下就行了
然后我们就发现datatypes下有了JSONArray!
然后浅浅地调用一下就行了~
query.X.Where(gen.Cond(datatypes.JSONArrayQuery("column_name").Contains("element"))...).Find()
完结撒花!
标签:CONTAINS,GORM,Array,JSON,go,datatypes,GEN From: https://www.cnblogs.com/Vikyanite/p/17126080.html