什么是mysql分区_数据库-什么是MYSQL分区?

分区背后的想法不是使用多个服务器,而是使用多个表而不是一个表。 您可以将一个表分为多个表,以便一个子表中可以包含旧数据,而另一个表中可以包含新数据。 然后,数据库可以优化查询,在知道新数据位于第二张表中的情况下,您可以在其中查询新数据。 此外,您可以定义如何对数据进行分区。

来自MySQL文档的简单示例:

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,

store_id INT

)

PARTITION BY RANGE ( YEAR(separated) ) (

PARTITION p0 VALUES LESS THAN (1991),

PARTITION p1 VALUES LESS THAN (1996),

PARTITION p2 VALUES LESS THAN (2001),

PARTITION p3 VALUES LESS THAN MAXVALUE

);

这样可以加快速度,例如:

简单删除旧数据:

SELECT COUNT(*)

FROM employees

WHERE separated BETWEEN '2000-01-01' AND '2000-12-31'

GROUP BY store_id;

数据库可以加快这样的查询:

SELECT COUNT(*)

FROM employees

WHERE separated BETWEEN '2000-01-01' AND '2000-12-31'

GROUP BY store_id;

知道所有数据仅存储在p2分区上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值