mysql 保存json多层数据,MYSQL查询返回JSON格式的字符串(多层嵌套)

简单的JSON格式请参看这篇博客:(https://blog.csdn.net/qq_39706570/article/details/104021291),本篇博客介绍复杂的嵌套方法。

表数据:

c1e994fb62a03cb3742e550c9d5f1c77.png

查询展示效果:

{

"department_no": [

{

"001": [

{"department_name": "诊疗部","doctor_name": "黄裳","doctor_no": "100011"},

{"department_name": "诊疗部","doctor_name": "花满楼","doctor_no": "100012"}

]

},

{

"002": [

{"department_name": "护理部","doctor_name": "风清扬","doctor_no": "100013"},

{"department_name": "护理部","doctor_name": "杨清风","doctor_no": "100014"}

]

}

]

}

查询方式:

SELECT CONCAT("{\"department_no\":[",GROUP_CONCAT(a.msg),"]}") FROM

(

SELECT

CONCAT("{\"",department_no,"\":"

"[",

GROUP_CONCAT(

"{"

"\"department_name\":\"",department_name,"\",",

"\"doctor_name\":\"",doctor_name,"\",",

"\"doctor_no\":\"",doctor_no,"\"","}"

),"]}"

) msg

FROM basic_hospital_information GROUP BY department_no

)a

注意:以上SQL查询方法是使用了

GROUP_CONCAT()

该函数有长度限制,一般默认长度为1024,可以使用这篇博客(https://blog.csdn.net/qq_39706570/article/details/103999965)轻松修改长度范围。

备注:小编写这篇博客不易,希望大家能给我点个赞,谢谢。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要将多重嵌套JSON 字符串解析为 Python 对象。你可以使用 Python 内置的 `json` 模块来实现,例如: ```python import json # 假设你的多重嵌套JSON 字符串为 data_str data = json.loads(data_str) ``` 然后,你可以使用 Python 的 MySQL 客户端库(例如 `mysql-connector-python`)连接到 MySQL 数据库,并创建表。你需要根据 JSON 数据的结构定义表的结构。例如,如果 JSON 数据的顶层是一个列表,每个列表项都是一个对象,你可以为每个对象定义一个表行。你可以使用 Python 的 `for` 循环遍历 JSON 数据,将每个对象转换为表行,并将其插入到 MySQL 表中。以下是一个示例代码: ```python import mysql.connector # 连接到 MySQL 数据库 cnx = mysql.connector.connect(user='your_username', password='your_password', host='your_host', database='your_database') cursor = cnx.cursor() # 假设你的 JSON 数据的结构如下: # [ # {"id": 1, "name": "John", "age": 30}, # {"id": 2, "name": "Jane", "age": 25} # ] # 创建表 create_table_query = ''' CREATE TABLE IF NOT EXISTS my_table ( id INT PRIMARY KEY, name VARCHAR(255), age INT ) ''' cursor.execute(create_table_query) # 遍历 JSON 数据,将每个对象插入到表中 for obj in data: insert_query = ''' INSERT INTO my_table (id, name, age) VALUES (%s, %s, %s) ''' cursor.execute(insert_query, (obj['id'], obj['name'], obj['age'])) cnx.commit() cursor.close() cnx.close() ``` 请注意,上面的示例代码仅作为参考。具体的实现方式可能因 JSON 数据的结构,以及你要存储的数据类型而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值