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 协议》,转载必须注明作者和本文链接
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

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