sql - 如何从 SQL 中提取 JSON 值,其中列值有时为空
问题描述
我有一个包含“sometimesjson”列的表,其中有时包含这样的值:
[{"id":111,"nam":"PROVIDER_this_one","qty":null}]
有时该字段完全为空,不仅仅是“[]”,而是完全为空/空字段。
所以我尝试用这个返回“PROVIDER_this_one”,但是错误......
CASE WHEN JSON_VALID(sometimesjson)
THEN
JSON_EXTRACT(sometimesjson, '$.nam')
AS 'FROMJSON'
ELSE null
有任何想法吗 ?
解决方案
我想到了。我猜是因为 json 值实际上是一个数组,所以我为该表字段值数组中的每个值调用“nam”的正确方法是...... '$[*].nam'而不是 '$.nam'它现在正在与...一起工作
CASE WHEN JSON_VALID(sometimesjson)
THEN
JSON_EXTRACT(sometimesjson, '$[*].nam')
AS 'FROMJSON'
ELSE null
推荐阅读
- javascript - 使用 Jasmine 测试链式承诺而不返回承诺
- django - 无法使用 DRF 在 Django 模板中显示图像
- wpf - 在本地/直接设置控件的(触发)属性时,ControlTemplate/Style 触发器不起作用
- javascript - Vue.js - 在另一个数组中显示嵌套数组的详细信息
- c - 如何反转C中的句子?
- paypal - 什么是 Paypal 的定期付款配置文件 RPSTATE 参数?
- postgresql - 更改 client_min_messages 和 log_min_messages
- python-3.x - 您如何比较包含不可散列对象的字典?
- c - 字符串计数问题、浮点整数、基于字母、单词和句子数量的评分公式,在 C 中
- jquery - 选中复选框时选择特定的单选选项jQuery