首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在MYSQL中的JSON字段中搜索值

在MYSQL中的JSON字段中搜索值
EN

Stack Overflow用户
提问于 2018-07-27 10:17:40
回答 2查看 388关注 0票数 1

我正在尝试理解“新”MYSQL字段。

我有一张桌子:

代码语言:javascript
复制
id (int-11, not_null, auto_inc)
customer_id (int-11, not null)
labels (json)

具有此数据的

代码语言:javascript
复制
id: 1
customer_id: 1
labels: [{"isnew": "no", "tagname": "FOO", "category": "CAT_1", "isdeleted": "no"}, {"isnew": "yes", "tagname": "BAR", "category": "CAT_2", "isdeleted": "no"}]

JSON美化

代码语言:javascript
复制
[
  {
    "tagname": "FOO",
    "category": "CAT_1",
    "isnew": "no",
    "isdeleted": "no"
  },
  {
    "tagname": "BAR",
    "category": "CAT_2",
    "isnew": "yes",
    "isdeleted": "no"
  }
]

现在,我希望选择表中具有特定类别和特定标签名的所有客户(按)。

我试过这个:

代码语言:javascript
复制
SELECT * FROM labels_customers_json
WHERE JSON_SEARCH(labels, 'all', 'BAR') IS NOT NULL

但这不是我想要的。这个在每个json属性中搜索。我看到了一些JSON_EXTRACT的例子:

代码语言:javascript
复制
SELECT * FROM `e_store`.`products`
WHERE
    `category_id` = 1
    AND JSON_EXTRACT(`attributes` , '$.ports.usb') > 0
    AND JSON_EXTRACT(`attributes` , '$.ports.hdmi') > 0;

SELECT c, c->"$.id", g, n
FROM jemp
WHERE JSON_EXTRACT(c, "$.id") > 1
ORDER BY c->"$.name";

所以我试了一下

代码语言:javascript
复制
SELECT * FROM labels_customers_json
WHERE JSON_EXTRACT(labels, '$.tagname') = 'BAR'

SELECT labels, JSON_EXTRACT(labels, "$.customer_id"), customer_id
FROM labels_customers_json
WHERE JSON_EXTRACT(labels, "$.customer_id") > 0
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-07-31 11:25:40

您也可以使用JSON_SEARCH搜索特定的路径。因此,您可以使用以下查询:

代码语言:javascript
复制
SELECT * 
FROM labels_customers_json 
WHERE JSON_SEARCH(labels, 'all', 'BAR', NULL, '$[*].tagname') IS NOT NULL

您还可以同时使用JSON_EXTRACTJSON_CONTAINS

代码语言:javascript
复制
SELECT *
FROM labels_customers_json
WHERE JSON_CONTAINS(JSON_EXTRACT(labels, '$[*].tagname'), '["BAR"]') > 0;

您还可以只使用JSON_CONTAINS来检查:

代码语言:javascript
复制
SELECT *
FROM labels_customers_json
WHERE JSON_CONTAINS(labels, '{"tagname":"BAR"}') > 0;

演示: https://www.db-fiddle.com/f/rufrThAQPfXHrK9YyibFSm/2

票数 1
EN

Stack Overflow用户

发布于 2018-07-27 16:18:56

您可能可以尝试使用SELECT * FROM labels_customers_json WHERE JSON_SEARCH(labels, 'all', "BAR", NULL, "$[*].tagname") is not null --尽管我不能说这是否是执行此查询的最佳方式。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51555847

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档