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,如需转载请自行联系原作者