gpt4 book ai didi

mysql - 如何比较 MySQL 5.6 中的 JSON-like 文本?

转载 作者:可可西里 更新时间:2023-11-01 07:45:38 25 4
gpt4 key购买 nike

数据库管理系统: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 的版本也是出于同样的考虑。所以我认为需要一个解决方法。

最佳答案

使用LOCATE

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

关于mysql - 如何比较 MySQL 5.6 中的 JSON-like 文本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34391767/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com