详细分析Mysql中的JSON_OBJECT() 基本知识(附Demo)

目录

  • 前言
  • 1. 基本知识
  • 2. Demo

前言

对于基本的命令行以及优化推荐阅读:

  1. 数据库中增删改常用语法语句(全)
  2. Mysql优化高级篇(全)
  3. 命令行登录Mysql的详细讲解

1. 基本知识

JSON_OBJECT() 是 MySQL 中用于生成 JSON 对象的函数

从一对或多对 key-value 参数创建一个 JSON 对象,其中每个 key 必须是字符串类型,而 value 可以是任何类型,包括字符串、数值、NULL、JSON 文本

基本语法如下:

JSON_OBJECT(key1, value1, key2, value2, ...)
  • key:必须是字符串类型
  • value:可以是任何类型(字符串、数值、NULL、JSON 等)

注意事项如下:

  • Key 必须是字符串:key 不是字符串类型,MySQL 会返回一个错误
  • Key 重复:如果在同一个 JSON_OBJECT() 函数中有重复的 key,后面的 key-value 对会覆盖前面的
  • NULL 处理:某个 value 是 NULL,那么生成的 JSON 对象中的对应 key 的值也是 NULL
  • 嵌套 JSON:可以嵌套使用,从而生成复杂的 JSON 结构
  • MySQL 版本:在 MySQL 5.7.8 及以上版本中引入的,因此需要确保 MySQL 版本支持此函数

2. Demo

基本的语句如下:SELECT JSON_OBJECT('id', 1, 'name', 'Alice', 'age', 30);

在这里插入图片描述

同样可处理Null值:SELECT JSON_OBJECT('id', 2, 'name', 'Bob', 'age', NULL);

在这里插入图片描述
嵌套JSON对象

SELECT JSON_OBJECT('id', 3,'name', 'Carol','address', JSON_OBJECT('city', 'New York', 'zip', '10001')
);

截图如下:

在这里插入图片描述
数组与 JSON_ARRAY() 的结合

SELECT JSON_OBJECT('id', 4,'name', 'David','scores', JSON_ARRAY(85, 90, 78)
);

截图如下:

在这里插入图片描述

当遇到多个key值一样,只会使用后面的key:SELECT JSON_OBJECT('id', 5, 'name', 'Eve', 'name', 'Eva');

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/24264.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

信息系统项目管理师0149:输入(9项目范围管理—9.4收集需求—9.4.1输入)

点击查看专栏目录 文章目录 9.4 收集需求9.4.1 输入9.4 收集需求 收集需求是为实现目标而确定,记录并管理干系人的需要和需求的过程。本过程的主要作用是为定义产品范围和项目范围奠定基础。本过程仅开展一次或仅在项目的预定义点开展。收集需求过程的数据流向如图 9-2 所示。…

「前端+鸿蒙」鸿蒙应用开发简介

鸿蒙应用开发是指使用华为鸿蒙操作系统(HarmonyOS)提供的API和开发工具,创建可以在鸿蒙设备上运行的应用程序。鸿蒙系统是华为开发的全场景、分布式操作系统,它支持多种设备类型,包括智能手机、平板电脑、智能电视、智…

Spring (45)Gateway

在计算机网络中,一个网关(Gateway)是一个网络节点,它充当不同网络协议、应用程序或数据格式之间的转换点。在微服务架构中,API网关(API Gateway)扮演着非常关键的角色,它是微服务和外…

电脑开机出现英文字母,如何解决这个常见问题?

电脑开机时出现英文字母的情况通常意味着系统在启动过程中遇到了问题。这些英文字母可能是错误信息、系统提示或BIOS设置问题。通过理解这些信息并采取适当的措施,您可以解决大多数启动问题。本文将介绍三种解决电脑开机出现英文字母问题的方法,帮助您恢…

智能合约中未授权访问

未授权访问: 如果智能合约对关键函数的访问控制不足,攻击者可能执行不应允许的操作,如修改合约状态或提取资金。 未授权访问示例 假设我们有一个智能合约,用于管理用户的存款和提款。在这个例子中,合约没有正确地限…

python使用appium打开程序后,为什么没有操作后程序就自动退出了

当使用Appium打开应用程序并在没有执行任何操作后它自动退出,这可能是由于几个不同的原因。以下是一些可能的原因和相应的解决方案: 应用程序的默认行为: 有些应用程序在启动后如果没有用户交互,可能会因为超时或其他逻辑而自动关…

BGP汇总+认证

一、BGP 的宣告问题 1、在 BGP 协议中每台运行 BGP 的设备上,宣告本地直连路由 2、在 BGP 协议中运行 BGP 协议的设备来宣告.通过 IGP 学习到的,未运行 BGP 协议设备产2、生的路由; 在 BGP 协议中宣告本地路由表中路由条目时,将携带本地到达这…

Spring Boot集成geodesy实现距离计算

1.什么是geodesy? 浩瀚的宇宙中,地球是我们赖以生存的家园。自古以来,人类一直对星球上的位置和彼此的距离着迷。无论是航海探险、贸易往来还是科学研究,精确计算两个地点之间的距离都是至关重要的。 Geodesy:大地测量…

Qt实现麦克风音频输入保存wav文件

一.本文目的 实现在Qt中接收麦克风数据并保存为WAV文件,使用QAudioInput来录音,并使用QFile来保存数据到WAV文件。 开发环境:QT5.12 本文用极简代码实现,核心代码只需不到100行。 完整工程代码文末链接可以直接下载。 二.代码实…

51单片机STC89C52RC——创建Keil项目

一,打开Keil5 菜单---project--New uVision Project... 二,新建项目文件夹 弹出选择文件夹对话框后,可以右键新建一个项目文件夹【文件夹名字可以随便取,自己看得懂就行,建议不要有特殊字符】,这样该项目…

MATLAB算法实战应用案例精讲-【数模应用】因子分析(附MATLAB和python代码实现)

目录 前言 算法原理 SPSS因子分析 操作步骤 结果分析 SPSSAU 因子分析案例 1、背景 2、理论 3、操作 4、SPSSAU输出结果 5、文字分析 6、剖析 疑难解惑 同源方差或共同方法变异偏差,Harman单因子检验? 提示出现奇异矩阵? 因子得分和综合得分? 因子分析计…

品牌策划:不只是工作,是一场创意与学习的旅程

你是否认为只有那些经验丰富、手握无数成功案例的高手才能在品牌策划界崭露头角? 今天,我要悄悄告诉你一个行业内的秘密:在品牌策划的世界里,经验虽重要,但绝非唯一。 1️、无止境的学习欲望 品牌策划,这…

rtl8723DU移植 android4.4 4418 (第二部分蓝牙部分)

使用的代码: HMI (8723bu)源码 567_RTL8723DU_WiFi_linux_v5.6.5.3_35502_COEX20181130-2e2e.20191025.zip 由于之前写的所有笔记没有保存,这里只能是部分。 0、 前置知识 1 、kernel 的移植 2、hardwire的移植 将 驱动中的 h…

流水线报错:[Error: ENOENT: no such file or directory, stat ‘/application/bin‘]

报错信息: #18 10.37 > Build error occurred #18 10.38 [Error: ENOENT: no such file or directory, stat /application/bin] { #18 10.38 errno: -2, #18 10.38 code: ENOENT, #18 10.38 syscall: stat, #18 10.38 path: /application/bin #18 10.38 } #18 12…

腾讯开源人像照片生成视频模型V-Express

网址 https://github.com/tencent-ailab/V-Express 下面是github里的翻译: 在人像视频生成领域,使用单张图像生成人像视频变得越来越普遍。一种常见的方法是利用生成模型来增强受控发电的适配器。 但是,控制信号的强度可能会有所不同&…

系统思考—啤酒游戏沙盘

10个智商120的‮组人‬成‮团的‬队,大‮的家‬集体智‮是商‬多少? 在‮期长‬辅‮各导‬种‮业企‬的‮程过‬中,我‮经们‬常‮察观‬到,虽‮每然‬个‮门部‬都‮力努‬解决‮己自‬的问题,但‮司公‬整体的‮收应…

Rust 标记一个属性或函数为废弃

如题,演示Rust 标记一个属性或函数为废弃的基本使用方法: 示例: use serde::{Deserialize, Serialize};#[derive(Clone, Debug, Serialize, Deserialize, Default)] pub struct GrpcOptions {pub addr: String,pub max_recv_message_size: u…

conntrack如何限制您的k8s网关

1.1 conntrack 介绍 对于那些不熟悉的人来说,conntrack简单来说是Linux内核的一个子系统,它跟踪所有进入、出去或通过系统的网络连接,允许它监控和管理每个连接的状态,这对于诸如NAT(网络地址转换)、防火墙和保持会话连续性等任务至关重要。它作为Netfilter的一部分运行,…

解决福昕风腾PDF套装无法打印在线电子签章的方法

使用福昕风腾PDF套装打印在线电子签章文件时发现,在线盖的电子印章和签名却打印不出来,后现发现,按图中选项选择“文档”,即可完整打印文件内容及电子签章。留印。

(求一个整数各位数的和)编写程序,读取一个在0和1000之间的整数,并将该整数的各位数字相加。例如:整数是 932,各位数字之和为14。

(求一个整数各位数的和)编写程序,读取一个在0和1000之间的整数,并将该整数 的各位数字相加。例如:整数是 932,各位数字之和为14。 提示:利用操作符%分解数字,然后使用操作符/去掉分解出来的数字。例如: 932%10-2 932/10-93。下面是一个运行示…