MySQL对数据表已有表进行分区表的实现

目录
  • 操作方式
  • 操作过程

对现有的一个表进行创建分区表,并把数据迁移到新表,可以按时间来分区,然后这表不是实时更新,每天有一次插入操作。
时间比较充裕,但是服务器上有其他应用,使用较小资源为主要方式。

操作方式

@1 可以使用alter table来进行更改表为分区表,这个操作会创建一个分区表,然后自动进行数据copy然后删除原表,
猜测服务器资源消耗比较大。

类似操作

alter table tbl_rtdata partition by range (month(fld_date))
(   
partition p_apr values less than (to_days('2012-05-01')),
partition p_may values less than (to_days('2012-06-01')), 
partition p_dec values less than maxvalue );

@2 新建一个和原来表一样的分区表,然后把数据从原表导出,接着倒入新表。
(原来的表主键只有id,而我的分区字段是 stsdate, 这里主键要修改为 id,stsdate 联合主键,分区表要求分区字段要是主键或者是主键的一部分)

操作过程

采用第二种方案。先创建分区表,然后导出原表数据,新表名称改为原表名,然后插入,最后建立普通索引。

建立分区表

create table `apdailysts_p` (
  `id` int(11) not null auto_increment,
  `ap_id` int(11) not null,
  `mac` varchar(17) not null,
  `liveinfo` longtext not null,
  `livetime` int(11) not null,
  `stsdate` date not null,
  `lastmodified` datetime not null,
   primary key (`id`, `stsdate`)
) 
partition by range columns(stsdate) (
    partition p0 values less than ('2016-06-01'),
    partition p1 values less than ('2016-07-01'),
    partition p2 values less than ('2016-08-01'),
    partition p3 values less than ('2016-09-01'),
    partition p4 values less than ('2016-10-01'),
    partition p5 values less than ('2016-11-01'),
    partition p6 values less than ('2016-12-01'),
    partition p7 values less than ('2017-01-01'),
    partition p8 values less than ('2017-02-01'),
    partition p9 values less than ('2017-03-01'),
    partition p10 values less than ('2017-05-01'),
    partition p11 values less than ('2017-06-01'),
    partition p12 values less than ('2017-07-01'),
    partition p13 values less than ('2017-08-01'),
    partition p14 values less than ('2017-09-01'),
    partition p15 values less than maxvalue
);

导出数据

mysqldump -u dbname -p --no-create-info dbname apdailysts  > apdailysts.sql

修改表名,导入数据(10分钟就导入完了,200w, 8g多一点数据),测试下ok,删除原来的表。

测试可以正常使用,收工,观察2天。。

– 10.16
通过这两天的观察,页面的查询速度从打不开到基本可以秒开的速度了,这个优化是成立的。

到此这篇关于mysql对数据表已有表进行分区表的实现的文章就介绍到这了,更多相关mysql 已有表进行分区表内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐