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