博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MariaDB 10.0.X中,动态列支持 JSON 格式来获取数据
阅读量:7127 次
发布时间:2019-06-28

本文共 3880 字,大约阅读时间需要 12 分钟。

MariaDB 10.0.X中,动态列(Dynamic Columns),可以支持 JSON 格式来获取数据。 

为了兼容传统SQL语法,MariaDB 10和MySQL5.7支持原生JSON格式,即关系型数据库和文档型NoSQL数据库集于一身

使用说明:

###表结构

1
2
3
4
create table assets (
  
item_name varchar(32) primary key, -- A common attribute 
for 
all items
  
dynamic_cols  blob  -- Dynamic columns will be stored here
);

###插入JSON格式数据

1
2
3
4
5
6
7
mysql> INSERT INTO assets VALUES 
    
->   (
'MariaDB T-shirt'
, COLUMN_CREATE(
'color'
'blue'
'size'
'XL'
));
Query OK, 1 row affected (0.02 sec)
 
mysql> INSERT INTO assets VALUES
    
->   (
'Thinkpad Laptop'
, COLUMN_CREATE(
'color'
'black'
'price'
, 500));
Query OK, 1 row affected (0.01 sec)

###获取Key(键)color的Value(值):

1
2
3
4
5
6
7
8
mysql> SELECT item_name, COLUMN_GET(dynamic_cols, 
'color' 
as char) AS color FROM assets;
+-----------------+-------+
| item_name       | color |
+-----------------+-------+
| MariaDB T-shirt | blue  |
| Thinkpad Laptop | black |
+-----------------+-------+
2 rows 
in 
set 
(0.00 sec)

###获取全部Key(键)

1
2
3
4
5
6
7
8
mysql> SELECT item_name, column_list(dynamic_cols) FROM assets;
+-----------------+---------------------------+
| item_name       | column_list(dynamic_cols) |
+-----------------+---------------------------+
| MariaDB T-shirt | `size`,`color`            |
| Thinkpad Laptop | `color`,`price`           |
+-----------------+---------------------------+
2 rows 
in 
set 
(0.00 sec)

###获取全部Key-Value

1
2
3
4
5
6
7
8
mysql> SELECT item_name, COLUMN_JSON(dynamic_cols) FROM assets;
+-----------------+-------------------------------+
| item_name       | COLUMN_JSON(dynamic_cols)     |
+-----------------+-------------------------------+
| MariaDB T-shirt | {
"size"
:
"XL"
,
"color"
:
"blue"
}  |
| Thinkpad Laptop | {
"color"
:
"black"
,
"price"
:500} |
+-----------------+-------------------------------+
2 rows 
in 
set 
(0.01 sec)

###删除一个Key-Value:

1
2
3
4
5
6
7
8
9
10
11
12
13
mysql> UPDATE assets SET dynamic_cols=COLUMN_DELETE(dynamic_cols, 
"price"
    
-> WHERE COLUMN_GET(dynamic_cols, 
'color' 
as char)=
'black'
;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0
 
mysql> SELECT item_name, COLUMN_JSON(dynamic_cols) FROM assets;
+-----------------+------------------------------+
| item_name       | COLUMN_JSON(dynamic_cols)    |
+-----------------+------------------------------+
| MariaDB T-shirt | {
"size"
:
"XL"
,
"color"
:
"blue"
} |
| Thinkpad Laptop | {
"color"
:
"black"
}            |
+-----------------+------------------------------+
2 rows 
in 
set 
(0.00 sec)

###增加一个Key-Value:

1
2
3
4
5
6
7
8
9
10
11
12
13
mysql> UPDATE assets SET dynamic_cols=COLUMN_ADD(dynamic_cols, 
'warranty'
'3 years'
)
    
-> WHERE item_name=
'Thinkpad Laptop'
;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0
 
mysql> SELECT item_name, COLUMN_JSON(dynamic_cols) FROM assets;                            
+-----------------+----------------------------------------+
| item_name       | COLUMN_JSON(dynamic_cols)              |
+-----------------+----------------------------------------+
| MariaDB T-shirt | {
"size"
:
"XL"
,
"color"
:
"blue"
}           |
| Thinkpad Laptop | {
"color"
:
"black"
,
"warranty"
:
"3 years"
} |
+-----------------+----------------------------------------+
2 rows 
in 
set 
(0.00 sec)

###更改一个Key-Value:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
mysql> UPDATE assets SET 
dynamic_cols=COLUMN_ADD(dynamic_cols,
'color'
'white'
) WHERE 
COLUMN_GET(dynamic_cols, 
'color' 
as char)=
'black'
;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0
 
mysql> SELECT item_name, COLUMN_JSON(dynamic_cols) FROM assets;
+-----------------+----------------------------------------+
| item_name       | COLUMN_JSON(dynamic_cols)              |
+-----------------+----------------------------------------+
| MariaDB T-shirt | {
"size"
:
"XL"
,
"color"
:
"blue"
}           |
| Thinkpad Laptop | {
"color"
:
"white"
,
"warranty"
:
"3 years"
} |
+-----------------+----------------------------------------+
2 rows 
in 
set 
(0.00 sec)

本文转自hcymysql51CTO博客,原文链接: http://blog.51cto.com/hcymysql/1694181,如需转载请自行联系原作者

你可能感兴趣的文章
快速了解掌握中文自然语言处理
查看>>
omni core api速查表
查看>>
比特币 的 正统 ——BCH
查看>>
【2018.07.11学习笔记】【linux高级知识 20.1-20.4】
查看>>
Spring Cloud Config客户端使用
查看>>
多年经验的大牛总结出来的Python案例超详细
查看>>
Gradle实现Android多渠道定制化打包
查看>>
Ubuntu 16.4下 Docker 安装文档
查看>>
GoJS图表组件简介
查看>>
百度AI开放平台,共建AI生态
查看>>
ES6 fetch函数与后台交互实现
查看>>
盘点5月份GitHub上最热门的开源项目
查看>>
SpringBoot + Dubbo的项目如何优雅停机
查看>>
Eclipse设置源文件的编码方式UTF-8
查看>>
ppt如何导出成高清图片
查看>>
PyQt5教程(七)——控件(II)
查看>>
Vyatta设置
查看>>
Redis核心解读–集群管理工具(Redis-sentinel)(转)
查看>>
删除排序数组中的重复元素java实现
查看>>
com.android.tools.fd.runtime.BootstrapApplication
查看>>