WEB开发网
开发学院数据库MySQL 理解MySQL——并行数据库与分区(Partion) 阅读

理解MySQL——并行数据库与分区(Partion)

 2009-12-30 00:00:00 来源:WEB开发网   
核心提示: 注:实际上,分区不论是对I/O并行,理解MySQL——并行数据库与分区(Partion)(7),还是查询内并行,都有着重要的影响,这20家音像店的编号从1到20,CREATETABLEemployees(idINTNOTNULL,fnameVARCHAR(30),lnameVARCHAR(30)

注:实际上,分区不论是对I/O并行,还是查询内并行,都有着重要的影响。只不过MySQL在这方面做得还不够多(不过,正在改进),而Oracle对于查询内并行,做了很多工作。

2.2、分区类型

MySQL 5.1中可用的分区类型包括:

    RANGE分区(portioning):根据列值所属的范围区间,将元组分配到各个分区。

    LIST分区:类似于按RANGE分区,区别在于LIST分区是基于列值匹配一个离散值集合中的某个值来进行选择。

    HASH分区:根据用户定义的函数的返回值来进行选择的分区,该表达式使用将要插入到表中的这些行的列值进行计算。这个函数可以包含MySQL 中有效的、产生非负整数值的任何表达式。

    KEY分区:类似于按HASH分区,区别在于KEY分区只支持计算一列或多列,且MySQL 服务器提供其自身的哈希函数。

2.2.1、范围分区

范围分区是通过计算表达式的值所属的范围区间,对元组进行分区。这些区间要求连续且不能相互重叠,使用VALUES LESS THAN操作符来进行定义。在下面的几个例子中,假定你创建了一个如下的一个表,该表保存有20家音像店的职员记录,这20家音像店的编号从1到20。

CREATE TABLE employees (
    id INT NOT NULL,
    fname VARCHAR(30),
    lname VARCHAR(30),
    hired DATE NOT NULL DEFAULT '1970-01-01',
    separated DATE NOT NULL DEFAULT '9999-12-31',
    job_code INT NOT NULL,
    store_id INT NOT NULL
);

你可以根据需要对该表进行各种分区,比如,你可以通过store_id来进行分区:

上一页  2 3 4 5 6 7 8 9 10  下一页

Tags:理解 MySQL 并行

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接