Java ->在mybatis和PostgreSQL Json字段作为查询条件的解决方案
因为喜欢 人气:1Date:2019-11-15
读前思考:
你没想到解决办法?
PostgreSQL 数据库本身就支持还是另有解决办法?
说明:首先这次数据库使用到Json数据类型的原因,这次因为我们在做了一个app 推送的业务,推送的时候,后端给app 推送 好几个字段的内容。 我们这里就直接使用了jsonb数据类型。
如下:
"rule":{ "tags": { "target": "logon" }, "time": "2019-11-15 10:00:00", "method": "scheduled", "source": "backend", "aliases": [], "sendType": "tag", "registrationIds": [] }
现在我想获取 rule 字段 里面的 sendType="tag",那现在怎么搞?
代码如下:
#####Mybatis##### <select id="selectPushDataList" resultMap="BaseResultMap" parameterType="com.jpc.JpushData" > SELECT <include refid="Base_Column_List" /> FROM jp_push jpt <where> delete_flag=1 and (rule::json->>'sendType')::text = 'tag' <if test="name != null and name !=''" > and name =#{name,jdbcType=VARCHAR} </if> ORDER BY create_time ASC LIMIT ${pageSize} OFFSET ${(currentPage - 1) * pageSize} </where> </select> ####PostgreSQL SQL#### SELECT uuid, create_user, create_time, update_user, update_time, delete_flag, NAME, type, push, rule, STATUS FROM jp_push jpt WHERE jpt.delete_flag = 1 AND ( jpct.rule :: json ->> 'sendType' ) :: text = 'tag' AND jpt.NAME = 'testname' ORDER BY jpt.create_time ASC LIMIT 20 OFFSET 0
结果如下:
加载全部内容