作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个存储 JSON 值的表。在这些 JSON 中,JSON 具有如下所示的 null 属性:
{
"name" : "AAAA",
"department" : "BBBB",
"countryCode" : null,
"languageCode" : null,
"region" : "AP"
}
我想编写一个查询,以便从输出中删除所有空属性。例如对于上述 JSON,结果输出 JSON 应该是这样的。
{
"name" : "AAAA",
"department" : "BBBB",
"region" : "AP"
}
我想要一个通用查询,可以将其应用于任何 JSON,以消除 MySQL (v5.7) 中的 null 属性。
最佳答案
如果您事先不知道所有 key :
WITH j AS (SELECT CAST('{"a": 1, "b": "null", "c": null}' AS JSON) o)
SELECT j.o, (SELECT JSON_OBJECTAGG(k, JSON_EXTRACT(j.o, CONCAT('$."', jt.k, '"')))
FROM JSON_TABLE(JSON_KEYS(o), '$[*]' COLUMNS (k VARCHAR(200) PATH '$')) jt
WHERE JSON_EXTRACT(j.o, CONCAT('$."', jt.k, '"')) != CAST('null' AS JSON)) removed
FROM j;
输出:
这将使您的 key 保持字符串值 "null"
,与 json null
不同.
关于mysql - 如何从 MySQL 中的 JSON 中删除空属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50940629/
我是一名优秀的程序员,十分优秀!