mysql分区错误代码1486_MySQL • 最佳实践 • 分区表基本类型

本文介绍了MySQL中不同类型的分区表,包括范围分区、时间戳分区、列表分区和哈希分区,并通过示例展示了如何创建和插入数据。同时,通过EXPLAIN分析了查询优化,特别是在时间范围查询上的性能表现。
摘要由CSDN通过智能技术生成

CREATE TABLE my_range_datetime(

id INT,

hiredate DATETIME

)

PARTITION BY RANGE (TO_DAYS(hiredate) ) (

PARTITION p1 VALUES LESS THAN ( TO_DAYS('20171202') ),

PARTITION p2 VALUES LESS THAN ( TO_DAYS('20171203') ),

PARTITION p3 VALUES LESS THAN ( TO_DAYS('20171204') ),

PARTITION p4 VALUES LESS THAN ( TO_DAYS('20171205') ),

PARTITION p5 VALUES LESS THAN ( TO_DAYS('20171206') ),

PARTITION p6 VALUES LESS THAN ( TO_DAYS('20171207') ),

PARTITION p7 VALUES LESS THAN ( TO_DAYS('20171208') ),

PARTITION p8 VALUES LESS THAN ( TO_DAYS('20171209') ),

PARTITION p9 VALUES LESS THAN ( TO_DAYS('20171210') ),

PARTITION p10 VALUES LESS THAN ( TO_DAYS('20171211') ),

PARTITION p11 VALUES LESS THAN (MAXVALUE)

);

复制代码mysql> insert into my_range_datetime select * from test;

Query OK, 1000000 rows affected (8.15 sec)

Records: 1000000 Duplicates: 0 Warnings: 0

mysql> explain partitions select * from my_range_datetime where hiredate >= '20171207124503' and hiredate<='20171210111230';

+----+-------------+-------------------+--------------+------+---------------+------+---------+------+--------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | Extra |

+----+-------------+-------------------+--------------+------+---------------+------+---------+------+--------+-------------+

| 1 | SIMPLE | my_range_datetime | p7,p8,p9,p10 | ALL | NULL | NULL | NULL | NULL | 400061 | Using where |

+----+-------------+-------------------+--------------+------+---------------+------+---------+------+--------+-------------+

1 row in set (0.03 sec)

复制代码CREATE TABLE my_range_timestamp (

id INT,

hiredate TIMESTAMP

)

PARTITION BY RANGE ( UNIX_TIMESTAMP(hiredate) ) (

PARTITION p1 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-02 00:00:00') ),

PARTITION p2 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-03 00:00:00') ),

PARTITION p3 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-04 00:00:00') ),

PARTITION p4 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-05 00:00:00') ),

PARTITION p5 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-06 00:00:00') ),

PARTITION p6 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-07 00:00:00') ),

PARTITION p7 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-08 00:00:00') ),

PARTITION p8 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-09 00:00:00') ),

PARTITION p9 VALUES LESS THAN ( UNIX_TIMESTAMP('2017-12-10 00:00:00') ),

PARTITION p10 VALUES LESS THAN (UNIX_TIMESTAMP('2017-12-11 00:00:00') )

);

复制代码mysql> insert into my_range_timestamp select * from test;

Query OK, 1000000 rows affected (13.25 sec)

Records: 1000000 Duplicates: 0 Warnings: 0

mysql> explain partitions select * from my_range_timestamp where hiredate >= '20171207124503' and hiredate<='20171210111230';

+----+-------------+-------------------+--------------+------+---------------+------+---------+------+--------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | Extra |

+----+-------------+-------------------+--------------+------+---------------+------+---------+------+--------+-------------+

| 1 | SIMPLE | my_range_timestamp | p7,p8,p9,p10 | ALL | NULL | NULL | NULL | NULL | 400448 | Using where |

+----+-------------+-------------------+--------------+------+---------------+------+---------+------+--------+-------------+

1 row in set (0.00 sec)

复制代码create table t_list(

a int(11),

b int(11)

)(partition by list (b)

partition p0 values in (1,3,5,7,9),

partition p1 values in (2,4,6,8,0)

);

复制代码CREATE TABLE my_member (

id INT NOT NULL,

fname VARCHAR(30),

lname VARCHAR(30),

created DATE NOT NULL DEFAULT '1970-01-01',

separated DATE NOT NULL DEFAULT '9999-12-31',

job_code INT,

store_id INT

)

PARTITION BY HASH(id)

PARTITIONS 4;

复制代码CREATE TABLE my_members (

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 LINEAR HASH( id )

PARTITIONS 4;

复制代码CREATE TABLE k1 (

id INT NOT NULL PRIMARY KEY,

name VARCHAR(20)

)

PARTITION BY KEY()

PARTITIONS 2;

复制代码CREATE TABLE tm1 ( mmysql

s1 CHAR(32)

)

PARTITION BY KEY(s1)

PARTITIONS 10;

复制代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值