您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

MariaDB 新特性介绍-动态虚拟列

2024/3/25 1:18:13发布25次查看
mariadb为nosql的扩展提供的另外一个特性 就是:动态列。对表的每一行都可以有一个“虚拟列”,该列可以用于保存一个对象的不同属性,每个属性在各行之间可以完全不同,“虚拟列”的个数和内容完全有应用程序来控制和解释。 nosql的另外一个好处就是,我存储
mariadb为nosql的扩展提供的另外一个特性 就是:动态列。对表的每一行都可以有一个“虚拟列”,该列可以用于保存一个对象的不同属性,每个属性在各行之间可以完全不同,“虚拟列”的个数和内容完全有应用程序来控制和解释。
nosql的另外一个好处就是,我存储的东西是一个没有结构的东西,而数据库则要求是一个固定列名,确定长度的一个个列。为了满足这个需求,mariadb引入了动态列的概念。它允许你在每一行上有一个“虚拟列”。这个虚拟列被作为一个额外的字段存在在blob中,并且有一系列函数用于创建,更新,删除,检查,查询这个列。 空说无凭,举例为证。我们先创建一个表t1,用来存储shirt,phone,computer商品的价格,其中dynstr就是用于做虚拟列的:
create table t1 (id int auto_increment primary key, name varchar(40), type enum (shirt, phone, computer), price decimal(10,2), dynstr mediumblob);
并插入一些数据:
insert into t1 (name, type, price, dynstr) values(funny shirt, shirt, 10.0, column_create(1, blue, 10, xl)),(nokia, phone, 649, column_create(1, black, 2, touchscreen)),(htc desire hd, phone, 579, column_create(1, black, 3, android)),(bm/lenovo thinkpad x60s, computer, 419, column_create(1, black, 3, linux));
这里利用了column_create()函数来创建动态列。插入的四条数据。针对各个不同的商品定义不同的属性。比如1在各个商品中表示的是颜色;3表示的是操作系统;10表示的是大小。每行数据的属性不完全相同,也不要求所有的属性值都需要包含在动态列中。那么,动态列的有哪些属性要怎么查看列:
select id, name, type, price, length(dynstr) as len, column_list(dynstr) as list from t1;
+----+-------------------------+----------+--------+------+------+| id | name | type | price | len | list |+----+-------------------------+----------+--------+------+------+| 1 | funny shirt | shirt | 10.00 | 17 | 1,10 || 2 | nokia | phone | 649.00 | 27 | 1,2 || 3 | htc desire hd | phone | 579.00 | 23 | 1,3 || 4 | bm/lenovo thinkpad x60s | computer | 419.00 | 21 | 1,3 |+----+-------------------------+----------+--------+------+------+
column_list()可以列出动态列到底有哪些属性,这样的话我们就可以根据属性过滤:
select name from t1 where column_get(dynstr, 1 as char(10)) = black;
+-------------------------+| name |+-------------------------+| nokia || htc desire hd || bm/lenovo thinkpad x60s |+-------------------------+
select name, column_get(dynstr, 1 as char(10)) from t1 where column_exists(dynstr, 1);
+-------------------------+--------+| name | colour |+-------------------------+--------+| funny shirt | blue || nokia | black || htc desire hd | black || bm/lenovo thinkpad x60s | black |+-------------------------+--------+
上面的第一条sql查询了颜色为black的所有产品哪些属性,第二条sql查询了存在颜色属性的所有行。对应的column_get() 函数表示获取对应属性的属性值。column_exists()函数表示动态列中是否存储了该属性值。我们也注意到,现在动态列的所有属性都是用数字来表示的。
前面都是对动态列创建和查询的例子,我们再看看更新的例子。比如我们需要对类型为‘computer’的数据加4g内存:?
update t1 set dynstr=column_add(dynstr, 15, 4g ram) where type=computer;select name, type, price, length(dynstr) as len, column_list(dynstr) as list from t1 where type=computer;
+-------------------------+----------+--------+------+--------+| name | type | price | len | list |+-------------------------+----------+--------+------+--------+| bm/lenovo thinkpad x60s | computer | 419.00 | 29 | 1,3,15 |+-------------------------+----------+--------+------+--------+
column_add()函数会给每个’computer’的行加上新的属性,属性值为‘4g ram’。不过,column_add()并不仅仅是添加,它和mysql的replace一样,如果发现相同类型的属性,对应的属性值将被覆盖。
动态列现在正在快速发展期,还存在一定的限制。比如:
列必须通过数字来标识;动态列对象最大只有536870911字节;创建索引问题;具体信息参考:http://kb.askmonty.org/en/dynamic-columns/
原文地址:mariadb 新特性介绍-动态虚拟列, 感谢原作者分享。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product