读前思考:

  你没想到解决办法?PostgreSQL 数据库本身就支持还是另有解决办法?

使用JOSNB作为字段类型。现在开始,,,,,,,,,,,,,,,,,,

json如下:

"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

结果如下:

再看如下的json串:

--如何获取title,description呢--------

----------pre- zh en app----------
"pre": {
"zh": {
"app": {
"title": "test",
"description": "test",
"images": [
"https://www.baidu.com/",
"https://www.baidu.com/1"
]
}
},
"en": {
"app": {
"title": "test",
"description": "test",
"images": [
"https://www.baidu.com/",
"https://www.baidu.com/1"
]
}
}
---------------pre zh en web------------------------------------
"pre": {
"zh": {
"web": {
"title": "test",
"description": "test",
"images": [
"https://www.baidu.com/",
"https://www.baidu.com/1"
]
}
},
"en": {
"web": {
"title": "test",
"description": "test",
"images": [
"https://www.baidu.com/",
"https://www.baidu.com/1"
]
}
}
}
如何写sql? 把语言和端作为一个变量传进去...
SELECT
    uuid, address,pre,
    pre :: json -> '${lunguage}' -> '${device}' ->> 'title' AS title,
    pre :: json -> '${lunguage}' -> '${device}' ->> 'description' AS description
FROM
  "ban".test j

获取 zh-web不为空的内容:

lunguage 传  zh,device传 web
SELECT
    uuid,address, pre,
    pre :: json -> '${lunguage}' -> '${device}' ->> 'title' AS title,
    pre :: json -> '${lunguage}' -> '${device}' ->> 'description' AS description
FROM
  "ban".test j where pre :: json -> '${lunguage}' -> '${device}' is not null

获取 zh-web-images数组里面的第一个图片信息不为空的内容:

SELECT 
uuid,address, pre,
    pre :: json -> '${lunguage}' -> '${device}' ->> 'title' AS title,
    pre :: json -> '${lunguage}' -> '${device}' ->> 'description' AS description,
pre :: json -> '${lunguage}' -> '${device}' ->>0::'images' AS images
FROM
 "ban".test j where pre :: json -> '${lunguage}' -> '${device}' is not null

总结:PostgreSQL 本身就支持以json作为sql的查询条件。

Java ->在mybatis和PostgreSQL Json字段作为查询条件的解决方案的更多相关文章

  1. PostgreSQL Json字段作为查询条件案例

    业务扩展字段在数据库中经常会使用json格式的数据来存储,这就涉及到一个头疼的问题,假设要使用扩展字段里的某个值作为查询条件怎么办,原来PostgreSQL本身就支持这种查询方式. 例子:假设业务扩展 ...

  2. mybatis 使用记录(二) 动态拼接查询条件

    2016-12-16 阅读项目代码时,在项目的xml文件中发现如下写法: SELECT student_user_id FROM tbr_student_class WHERE 1=1 <if ...

  3. thinkphp 同一字段不同查询条件实现

    搞定了 另外区间查询还可以支持更多的条件,只要是针对一个字段的条件都可以写到一起,例如:$map['name'] = array(array('like','%a%'), array('like',' ...

  4. Spark SQL解析查询parquet格式Hive表获取分区字段和查询条件

    首先说一下,这里解决的问题应用场景: sparksql处理Hive表数据时,判断加载的是否是分区表,以及分区表的字段有哪些?再进一步限制查询分区表必须指定分区? 这里涉及到两种情况:select SQ ...

  5. 【mysql】mysql5.7支持的json字段查询【mybatis】

    mysql5.7支持的json字段查询 参考:https://www.cnblogs.com/ooo0/p/9309277.html 参考:https://www.cnblogs.com/pfdltu ...

  6. 【mysql】 mybatis实现 主从表 left join 1:n 一对多 分页查询 主表从表都有查询条件 【mybatis】count 统计+JSON查询

    mybatis实现 主从表 left join  1:n 一对多 分页查询   主表从表都有查询条件+count 需求: ======================================= ...

  7. Java更新Oracle的clob类型字段

    Java更新Oracle的clob类型字段 1.查询该clob字段 2.处理该clob字段查询结果 3.更新该clob字段查询结果 1.查询该clob字段 <select id="se ...

  8. SQL性能优化-查询条件与字段分开执行,union代替in与or,存储过程代替union

    PS:概要.背景.结语都是日常“装X”,可以跳过直接看优化历程 环境:SQL Server 2008 R2.阿里云RDS:辅助工具:SQL 审计 概要 一个订单列表分页查询功能,单从SQL性能来讲,从 ...

  9. mybatis&plus系列------Mysql的JSON字段的读取和转换

    mybatis&plus系列------Mysql的JSON字段的读取和转换 一. 背景 在平常的开发中,我们可能会有这样的需求: 业务数据在存储的时候,并不是以mysql中的varchar丶 ...

随机推荐

  1. TCP三次握手、四次握手

    前言 TCP用于应用程序之间的通信.当应用程序希望通过TCP与另一个应用程序通信时,它会发送一个通信请求.这个请求必须被送到一个确切的地址.在双方“握手”之后,TCP将在两个应用程序之间建立一个全双工 ...

  2. css父元素透明度(opacity)对子元素的影响

    首先子元素会继承父元素的透明度: 设置父元素opacity:0.5,子元素不设置opacity,子元素会受到父元素opacity的影响,也会有0.5的透明度. 其次子元素的透明度是基于父元素的透明度计 ...

  3. django数据库迁移时候异常

    django数据库迁移时候异常 一.错误信息 Django在根据models生成数据库表时报 init() missing 1 required positional argument: 'on_de ...

  4. Pillow模块图片生成

    0825自我总结 Pillow模块图片生成 一.模块安装 pip3 install pillow 二.模块的载入 import PIL 三.django结合img标签生成图片 img.html < ...

  5. Ubuntu和开发板用网线直连ping不通的问题

    我装的Ubuntu 18.04双系统,在通过网络加载内核和文件系统那一步一直连接不上,uboot里面ping我的主机IP地址,提示: ping failed; host 192.168.1.111 i ...

  6. 数据挖掘:python数据清洗cvs里面带中文字符

    数据清洗,使用python数据清洗cvs里面带中文字符,意图是用字典对应中文字符,即key值是中文字符,value值是index,自增即可:利用字典数据结构没有重复key值的特性,把中文字符映射到了数 ...

  7. php 学习编译扩展

    原文 : http://kimi.it/496.html 系统环境 : Ubuntu 目标 : 可以像 php 提供的内部函数一样,使用 myecho 函数 : 输出如下 : 1. 获取 php 的源 ...

  8. [JOYOI1510] 专家复仇 - Floyd

    题目限制 时间限制 内存限制 评测方式 题目来源 1000ms 131072KiB 标准比较器 Local 题目背景 外星人完成对S国的考察后,准备返回,可他们的飞碟已经没燃料了……S国的专家暗自窃喜 ...

  9. ES6入门之变量的解构赋值(二)

    前言 在上一章 ES6入门之let和const命令中我们对ES6的相关语法已经有了初步了解,上一章中我们主要学习了三大部分的内容,let命令的使用,块级作用域,const命令的使用,那么从本篇博客将进 ...

  10. docker实验--redis集群搭建

    背景介绍: 我经常在做一些小项目的时候,采用了Redis来做缓存,但是都是基于单节点的,一旦redis挂了,整个项目就挂了.于是乎,想到了多节点集群的方式来使用,就开始折腾着怎么去搭建这个集群.在网上 ...