mysql json 存储_Mysql存储JSON字符串(数组)的操作
时间: 2024-01-19 13:04:56 浏览: 91
MySQL 5.7开始支持JSON数据类型,可以将JSON字符串存储在数据库中。下面是存储JSON字符串(数组)的操作:
1. 创建表时指定JSON类型的字段
创建表时,可以使用JSON类型来定义一个字段,例如:
```sql
CREATE TABLE `test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`json_data` json DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
```
这里定义了一个名为`json_data`的JSON类型的字段。
2. 插入JSON数据
插入JSON数据时,可以使用`JSON_OBJECT()`函数创建一个JSON对象,或者使用`JSON_ARRAY()`函数创建一个JSON数组。
例如,插入一个JSON对象:
```sql
INSERT INTO `test` (`json_data`) VALUES (JSON_OBJECT('name', 'John', 'age', 30));
```
插入一个JSON数组:
```sql
INSERT INTO `test` (`json_data`) VALUES (JSON_ARRAY('apple', 'banana', 'orange'));
```
3. 查询JSON数据
查询JSON数据时,可以使用`JSON_EXTRACT()`函数提取JSON对象或数组中的某个值。
例如,查询`json_data`字段中的`name`值:
```sql
SELECT JSON_EXTRACT(`json_data`, '$.name') FROM `test`;
```
查询`json_data`字段中的第二个元素:
```sql
SELECT JSON_EXTRACT(`json_data`, '$[1]') FROM `test`;
```
4. 更新JSON数据
更新JSON数据时,可以使用`JSON_SET()`函数或`JSON_REPLACE()`函数。
例如,将`json_data`字段中的`age`值更新为`40`:
```sql
UPDATE `test` SET `json_data` = JSON_SET(`json_data`, '$.age', 40) WHERE `id` = 1;
```
将`json_data`字段中的第二个元素更新为`grape`:
```sql
UPDATE `test` SET `json_data` = JSON_REPLACE(`json_data`, '$[1]', 'grape') WHERE `id` = 2;
```
以上就是MySQL存储JSON字符串(数组)的操作。
阅读全文
相关推荐
















