在mybatis和PostgreSQL Json字段做为查询条件的解决方案

Date:2019-11-15数据库

 读前思考:json

     你没想到解决办法?后端

    PostgreSQL 数据库自己就支持仍是另有解决办法?app

 

 说明:首先此次数据库使用到Json数据类型的缘由,此次由于咱们在作了一个app 推送的业务,推送的时候,后端给app 推送 好几个字段的内容。 咱们这里就直接使用了jsonb数据类型。ui

使用推送技术:极光推送spa

如今开始正事了,code

以下:blog

"rule":{
    "tags": {
        "target": "logon"
    },
    "time": "2019-11-15 10:00:00",
    "method": "scheduled",
    "source": "backend",
    "aliases": [],
    "sendType": "tag",
    "registrationIds": []
}

如今我想获取 rule 字段 里面的  sendType="tag",那如今怎么搞?get

代码以下:io

 

 

  #####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

 

结果以下:

相关文章
相关标签/搜索