mysql分表之水平分割

database

一、背景

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

二、水平分割

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

三、步骤。

  1. 做好备份
  2. 根据年份创建分区表(t_user_data_年份)

    1-- 创建和原表结构相同的分区表

    2createtable t_user_data_2019 like t_sys_user;

    3createtable t_user_data_2018 like t_sys_user;

    4createtable t_user_data_2017 like t_sys_user;

    5createtable t_user_data_2016 like t_sys_user;

  3. 找出各年份的数据,并将其插入到分区表

    1-- 找出各个年份的数据,并将其插入到分区表

    2select*from t_sys_user where DATE_FORMAT(create_time,"%Y") ="2017";

    3INSERTINTO t_user_data_2017 select*from t_sys_user where DATE_FORMAT(create_time,"%Y") ="2017";

    4select*from t_sys_user where DATE_FORMAT(create_time,"%Y") ="2018";

    5INSERTINTO t_user_data_2018 select*from t_sys_user where DATE_FORMAT(create_time,"%Y") ="2018";

    6select*from t_sys_user where DATE_FORMAT(create_time,"%Y") ="2019";

    7INSERTINTO t_user_data_2019 select*from t_sys_user where DATE_FORMAT(create_time,"%Y") ="2019";

  4. 记录及备份

以上是 mysql分表之水平分割 的全部内容, 来源链接: utcz.com/z/531775.html

回到顶部