Mysql 使用JSON_SEARCH函数 判断多表查询时,某个拼接字段是否包含另外一个字段

场景

两个表管理查询 关联字段为A表id, B表的ids

A表id是正常的整数, B的ids是id拼接成的字符类型, 格式是111,222,333这样的.

复制代码
A:                    B: 
    id                    ids
    11                    11,22,33
    22                    33,44,55
    33                    22

现在问题是 其他条件匹配的情况下,在判断下a.id是否在b.ids中

直接用字符串操作的话感觉有点无从下手, 因为判断包含的话会有特殊情况的存在,比如112,223包含11,但是显然他们不匹配.


问题解决

我是将ids拼接成了jsonArray,然后使用JSON_SEARCH判断包含的.

格式 JSON_SEARCH(jsonArray串,'匹配类型','查找字段')

sql 复制代码
select * from a left join b on a.xx=b.xx 
    and 
        json_search( concat( '["', replace( b.ids, ',', '","' ), '"]' ), 'one', a.id )
        IS NOT NULL  ;

Select JSON_SEARCH('["111","222","333","111222333"]','all',"111") from dual;   
输出: "$[0]" 说明存在 不存在的话是null

第一个参数json数组可以是表的字段, 也可以是表字段或者纯字符拼接起来的. 但是需要注意的是, 元素是整数类型的JsonArray时,是查不出来的. 必须要拼成字符类型的. a.org_ids是varchar类型, 格式是132,323,123 这样的类型, s.org_id 是单个的id 直接拼接[132,323,123] 这样的话是查不出来里面的元素的. 需要转成["132","323","123"]这样的.

第二个参数是 'one' 或 'all'。如果指定 'one',则查询只返回一个匹配项;如果指定 'all',则查询返回数组中所有匹配的项。

sql 复制代码
Select JSON_SEARCH('["111","222","111","111222333"]','all',"111") from dual;   
输出: "["$[0]", "$[2]"]" 说明存在 2个

此外还有JSON_EXTRACT / JSON_CONTAINS等函数可以了解

sql 复制代码
-----------------------------------------------------------------------------------
        JSON_EXTRACT,可以从JSONArray中提取出指定索引位置的值
            Select JSON_EXTRACT('["111","222","333","111222333"]','$[0]') from dual;   
            返回111. 可以搭配like判断包含
       
         JSON_CONTAINS, 判断是否包含元素
            Select JSON_CONTAINS('["111","222","333","111222333"]','["1"]', '$') from dual         
            存在返回1, 不存在返回0

后来又想到一种方法. 将b.ids拼接为 "123","456","789" 这样格式的字符串, 然后再将a.id拼接成"123". 然后 使用 LOCATE(substr,str)/POSITION(substr IN str)/INSTR(str,substr) 等函数, 判断是否存在也可以实现.


其实问题的关键在于将ids里面的每个id边缘确定,

相关推荐
MAGICIAN...1 小时前
【Redis】--持久化机制
数据库·redis·缓存
我真的是大笨蛋1 小时前
JVM调优总结
java·jvm·数据库·redis·缓存·性能优化·系统架构
步步为营DotNet3 小时前
5-2EFCore性能优化
数据库·性能优化·.net
2501_920047034 小时前
Redis-集群
数据库·redis·bootstrap
半夏陌离4 小时前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构
旋转的油纸伞4 小时前
SQL表一共有几种写入方式
数据库·sql
半夏陌离4 小时前
SQL 入门指南:排序与分页查询(ORDER BY 多字段排序、LIMIT 分页实战)
java·前端·数据库
isyoungboy4 小时前
SQL高效处理海量GPS轨迹数据:人员gps轨迹数据抽稀实战指南
数据库·sql
敬业小码哥5 小时前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
练小杰6 小时前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库