最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-09 13:14:40
文档

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

MariaDB新特性介绍-动态虚拟列:MariaDB为NoSQL的扩展提供的另外一个特性 就是:动态列。对表的每一行都可以有一个虚拟列,该列可以用于保存一个对象的不同属性,每个属性在各行之间可以完全不同,虚拟列的个数和内容完全有应用程序来控制和解释。 NoSQL的另外一个好处就是,我存储
推荐度:
导读MariaDB新特性介绍-动态虚拟列:MariaDB为NoSQL的扩展提供的另外一个特性 就是:动态列。对表的每一行都可以有一个虚拟列,该列可以用于保存一个对象的不同属性,每个属性在各行之间可以完全不同,虚拟列的个数和内容完全有应用程序来控制和解释。 NoSQL的另外一个好处就是,我存储


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", 9, 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 | 9.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新特性介绍-动态虚拟列

    MariaDB新特性介绍-动态虚拟列:MariaDB为NoSQL的扩展提供的另外一个特性 就是:动态列。对表的每一行都可以有一个虚拟列,该列可以用于保存一个对象的不同属性,每个属性在各行之间可以完全不同,虚拟列的个数和内容完全有应用程序来控制和解释。 NoSQL的另外一个好处就是,我存储
    推荐度:
    标签: 介绍 动态 虚拟
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top