MariaDB 特性介绍-动态虚拟列

MariaDB 特性介绍-动态虚拟列

  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/


原文转自:http://ourmysql.com/archives/1211

<think>好的,我现在需要解释MariaDB是什么。用户之前问过关于安装MySQL的问题,现在转而询问MariaDB,可能是因为之前的回答提到了MariaDB作为替代方案,用户想进一步了解。 首先,我应该从MariaDB的定义开始,说明它是MySQL的一个分支。需要强调它由原MySQL开发者创建,这样用户能理解两者的联系。接着,说明开发背景,比如MySQL被Oracle收购后的担忧,这样用户能明白为何MariaDB会出现。 然后,要比较MariaDB和MySQL的兼容性,指出大多数情况下兼容,但高版本可能有差异。这样用户知道迁移的可能影响。提到性能改进和新特性,比如存储引擎和扩展功能,可以展示MariaDB的优势。 还需要提到主要特点,比如开源协议、社区驱动、支持多种存储引擎等。这些信息帮助用户了解其优势。应用场景部分,区分普通Web应用和需要新特性的情况,帮助用户决定何时选择MariaDB。 最后,安装和使用部分要简明,结合用户之前的命令,给出安装步骤,确保用户能实际操作。可能还需要说明如何切换到MariaDB,特别是如果他们之前安装了MySQL,需要注意冲突和迁移步骤。 需要确保语言口语化,避免技术术语过多,结构清晰。检查是否有遗漏点,比如许可证差异或具体性能优化的例子,是否需要详细展开。可能用户关心兼容性程度,是否需要举例说明不兼容的情况,比如某些特定的MySQL功能在MariaDB中的变化。 总结下来,结构应该是:定义、背景、与MySQL的关系、特点、适用场景、安装使用。这样用户能全面了解MariaDB是什么,为何选择它,以及如何开始使用。</think>MariaDB 是一个**开源关系型数据库管理系统**,可简单理解为 **MySQL 的增强版分支**。以下是关键信息整理: --- ### **1. 起源背景** - **诞生原因**:MySQL 被 Oracle 收购后,原开发团队担心其开源持续性,于 2009 年创建了 MariaDB - **核心目标**:保持与 MySQL 的兼容性,同时提供更开放、高性能的替代方案 --- ### **2. 核心特点** | 特性 | 说明 | |---------------------|----------------------------------------------------------------------| | **完全开源** | 使用 GPL/LGPL 许可证,无商业限制 | | **兼容性** | 支持 MySQL 的协议、接口和命令,可直接替换 | | **性能优化** | 改进查询优化器,支持并行复制、线程池等 | | **存储引擎** | 默认使用 `Aria`(替代 MyISAM),同时包含 `InnoDB`、`RocksDB` 等 | | **扩展功能** | 新增动态虚拟、GIS 扩展等高级功能 | --- ### **3. 与 MySQL 的关键差异** | 对比项 | MariaDB | MySQL | |-----------------|------------------------------|------------------------------| | 开发团队 | 开源社区主导 | Oracle 公司主导 | | 版本兼容 | 支持 MySQL 5.x 兼容,**10.x 版本后差异增大** | 后续版本功能逐渐闭源化 | | 新特性迭代 | 更激进(如支持 `WITH` 语句、`JSON` 增强) | 较保守 | | 默认配置 | 更注重性能优化 | 偏重稳定性 | --- ### **4. 应用场景** - ✅ **推荐使用**: - 需要免费开源且长期维护的数据库 - 原有 MySQL 项目迁移(低版本可平滑过渡) - 需要 `GIS` 地理信息处理或特定扩展功能 - ⚠️ **谨慎选择**: - 依赖 MySQL 8.0+ 独有功能(如 `Invisible Indexes`) - 企业需 Oracle 官方商业支持的情况 --- ### **5. 安装与使用(以 CentOS 为例)** ```bash # 安装 MariaDB 服务端 sudo yum install mariadb-server # 启动服务并设置开机自启 sudo systemctl enable --now mariadb # 安全初始化(设置 root 密码等) sudo mysql_secure_installation # 连接数据库 mysql -u root -p ``` --- ### **6. 如何选择?** - **普通 Web 应用**:优先选 MariaDB(性能更好、社区活跃) - **依赖 MySQL 新特性**:需评估兼容性(可通过 [官方兼容手册](https://mariadb.com/kb/en/mariadb-vs-mysql-compatibility/) 核对) - **企业级需求**:考虑 MariaDB 的商业支持版或 MySQL 企业版 --- 📌 **总结**:MariaDB 继承了 MySQL 的核心优势,并持续在开源生态中创新,目前已成为 **Linux 发行版(如 CentOS、Ubuntu)的默认数据库**。除非有强制的 MySQL 依赖,否则建议优先选择 MariaDB
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值