如何在 MySQL 5.6 中比较类似 JSON 的文本?

Posted

技术标签:

【中文标题】如何在 MySQL 5.6 中比较类似 JSON 的文本?【英文标题】:How to compare JSON-like text in MySQL 5.6? 【发布时间】:2016-03-27 07:07:00 【问题描述】:

数据库管理系统:mysql 5.6

我有一个表tbl,其中json 列存储类似JSON 的文本,列的类型是textjson 的列看起来像

"id": "123", "name": "foo", "age": "20"

我尝试选择条件为json.id = '123' 的行。查询select * from tbl where json like '%"id": "123"%' 失败。

我发现 MySQL 5.6 不支持 Json 函数。那么如何在WHERE子句中使用Json呢?


追加

将 JSON 存储在单个列中的架构绝对不是那么合理。但我无法修改架构,因为业务已经运行了一段时间。 MySQL 的版本是出于同样的考虑。所以我认为需要一种解决方法。

【问题讨论】:

你没有——你规范化你的数据(使用列idnameage)或者至少规范化你要选择数据的内容。您可以期望的最好的结果是使用正则表达式来选择您的数据和/或通过将整个事物视为字符串来进行搜索。 如果可能,请使用 PostgreSQL。它有很好的JSON support @LukaszWiktor 如果可能的话,他肯定会使用 MySQL 5.7 considering it has JSON support as well(来自 5.7.8) @h2ooooooo 很高兴知道 MySQL 也可以处理 JSON。谢谢! @h2ooooooo 在 MySQL 5.7 支持 json 查询时听起来很棒 【参考方案1】:

使用LOCATE

Select * from tbl where 
LOCATE('"id": "123"','"id": "123", "name": "foo", "age": "20"') >0

【讨论】:

LOCATE like String.indexOf() function in some language【参考方案2】:

试试这个,common_schema是用来解析json的,

SELECT json 
    FROM tbl
    WHERE common_schema.extract_json_value(json ,'id')
    LIKE "123%"

【讨论】:

【参考方案3】:
select * from tbl where json like '%\"id\": \"123\"%'

试试这个。我已经转义了 " 字符。

【讨论】:

好主意,但当表有很多这样的行(json字符串)时不会优化查询速度

以上是关于如何在 MySQL 5.6 中比较类似 JSON 的文本?的主要内容,如果未能解决你的问题,请参考以下文章

拉拉维尔 5.6。如何测试 JSON/JSONb 列

在mysql(5.6)数据库中存储json数组的数据类型[关闭]

如果将json格式数据存储到类似mysql这样的关系型数据库中,怎么查

mysql 列转行 并进行json截取(mysql 5.6)

MYSQL 5.6中禁用INNODB引擎

MySQL 5.6 - DENSE_RANK 类似没有 Order By 的功能