Mysql 中 json、JsonArray 类型字段中指定属性的模糊查询问题

解决json类型字段的模糊查询:

存储的数据格式:{“type”: “10”, “mobile”: “13545678900”, “countryCode”: “86”, “name”:张三的订单}

select * from a where mobile_json->’$.mobile’ like ‘%135%’

解决json类型字段的精确查询

数据存储格式:{“type”: “10”, “mobile”: “13545678900”, “countryCode”: “86”, “name”:张三的订单}

select * from a where mobile_json-> ‘$.mobile’ = 13545678900

解决 JsonArray 类型字段的模糊查询:

存储的数据格式: [{“type”: “10”, “mobile”: “13545678900”, “countryCode”: “86”, “name”:张三的订单}]

select * from a where mobile_json->’$[*].mobile’ like ‘%135%’

select * from a where JSON_EXTRACT(mobile_json, ‘$[*].mobile’) LIKE ‘%$135%’

解决 JsonArray 类型字段的精确查询:

存储的数据格式: [{“type”: “10”, “mobile”: “13545678900”, “countryCode”: “86”, “name”:张三的订单}]

select * from a where JSON_CONTAINS(mobile_json,JSON_OBJECT(‘mobile’, “13545678900”))

thinkphp 或 laravel 写法

// 精确匹配
$query->whereRaw(“JSON_CONTAINS(mobile_json, JSON_OBJECT(‘mobile’, “. $value.”))” )

// 模糊匹配
$query->whereRaw(“mobile_json->’$[*].name’ like ‘%$value%’” );

$query->whereRaw(“JSON_EXTRACT(mobile_json, ‘$[*].name’) LIKE ‘%$value%’” );

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!