文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

sql json数组取值的方法是什么

程序界的探秘者

程序界的探秘者

2024-04-12 14:34

关注

这篇文章将为大家详细讲解有关sql json数组取值的方法是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

取值方法

1. 使用 JSON_VALUE 函数

语法:

JSON_VALUE(json_column, "$.key")

示例:

SELECT JSON_VALUE(user_data, "$.name")
FROM user_table;

2. 使用 JSON_EXTRACT 函数

语法:

JSON_EXTRACT(json_column, "$.key")

示例:

SELECT JSON_EXTRACT(user_data, "$.address.city")
FROM user_table;

3. 使用 -> 操作符

语法:

json_column -> "key"

示例:

SELECT user_data -> "name"
FROM user_table;

4. 使用 ->$ 操作符 (仅 MySQL 8+)

语法:

json_column -> "$."key"

示例:

SELECT user_data -> "$."address.city"
FROM user_table;

5. 使用 JSON_QUERY 函数

语法:

JSON_QUERY(json_column, "$.key")

示例:

SELECT JSON_QUERY(user_data, "$.name")
FROM user_table;

6. 使用 XPath 表达式

语法:

XPATH(json_column, "//key/@attribute")

示例:

SELECT XPATH(user_data, "//address/city/@id")
FROM user_table;

7. 使用 unnest() 和 json_value() 函数

语法:

unnest(json_array) AS key, value
SELECT json_value(value, "$.key") AS subvalue
FROM user_table
CROSS JOIN unnest(user_data) AS t(json_array)
WHERE key = "key_name";

示例:

SELECT subvalue
FROM user_table
CROSS JOIN unnest(user_data) AS t(json_array)
WHERE key = "tags";

8. 使用 lateral() 和 json_each() 函数

语法:

FROM LATERAL(
  JSON_EACH(json_column) AS key VALUE value
)
SELECT key, value;

示例:

FROM LATERAL(
  JSON_EACH(user_data) AS key VALUE value
)
SELECT key, value
FROM user_table;

以上就是sql json数组取值的方法是什么的详细内容,更多请关注编程学习网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯