欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mysql分表之水平分割

程序员文章站 2022-11-07 16:47:00
一、背景 老大安排要对某张大容量表进行分割,根据年份分割成多张表。 二、水平分割 水平拆分是指数据表行的拆分,表的行数超过百万行时,就会变慢,这时可以把一张的表的数据拆成多张表来存放。 定义规则分表后,表结构与原表相同,查询性能会提高。 ····· 三、步骤。 做好备份 根据年份创建分区表(t_us ......

一、背景

  1. 老大安排要对某张大容量表进行分割,根据年份分割成多张表。

二、水平分割

  1. 水平拆分是指数据表行的拆分,表的行数超过百万行时,就会变慢,这时可以把一张的表的数据拆成多张表来存放。
  2. 定义规则分表后,表结构与原表相同,查询性能会提高。
  3. ·····

三、步骤。

  1. 做好备份
  2. 根据年份创建分区表(t_user_data_年份)
    1 -- 创建和原表结构相同的分区表
    2 create table t_user_data_2019 like t_sys_user;
    3 create table t_user_data_2018 like t_sys_user;
    4 create table t_user_data_2017 like t_sys_user;
    5 create table t_user_data_2016 like t_sys_user;
  3. 找出各年份的数据,并将其插入到分区表
    1 -- 找出各个年份的数据,并将其插入到分区表
    2 select * from t_sys_user where date_format(create_time,'%y') = '2017';
    3 insert into  t_user_data_2017 select * from t_sys_user where date_format(create_time,'%y') = '2017';
    4 select * from t_sys_user where date_format(create_time,'%y') = '2018';
    5 insert into  t_user_data_2018 select * from t_sys_user where date_format(create_time,'%y') = '2018';
    6 select * from t_sys_user where date_format(create_time,'%y') = '2019';
    7 insert into  t_user_data_2019 select * from t_sys_user where date_format(create_time,'%y') = '2019';
  4. 记录及备份