登录
首页 >  数据库 >  MySQL

mysql merge 分区

来源:SegmentFault

时间:2023-01-26 15:18:15 222浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《mysql merge 分区》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

1.插入测试数据

1.usera 插入500w数据
2.userb 插入500w数据
3.userall (主表)
  •     usert1 (子表) 插入250w数据
  •     usert2 (子表) 插入250w数据
4.userall2 (主表)
  •     usert3 (子表) 插入250w数据
  •     usert4 (子表) 插入250w数据

  • 建表语句

CREATE TABLE usertb(
    id serial,
    uname  varchar(20) ,
    ucreatetime  datetime  ,
    age int(11))
ENGINE=MYISAM
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
AUTO_INCREMENT=1
ROW_FORMAT=COMPACT;

CREATE TABLE usertall(
    id serial,
    uname  varchar(20) ,
    ucreatetime  datetime  ,
    age int(11))
ENGINE=MERGE union(usert1,usert2) insert_method=last
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
AUTO_INCREMENT=1
ROW_FORMAT=COMPACT;
  • 使用存储过程插入测试数据

delimiter $$
SET AUTOCOMMIT = 0$$
create  procedure test1()
begin
declare v_cnt decimal (10)  default 0 ;
dd:loop
        insert into userta values
        (null,'用户1',now(),20),
        (null,'用户2',now(),20),
        (null,'用户3',now(),20),
        (null,'用户4',now(),20),
        (null,'用户5',now(),20),
        (null,'用户6',now(),20),
        (null,'用户7',now(),20),
        (null,'用户8',now(),20),
        (null,'用户9',now(),20),
        (null,'用户0',now(),20);
        commit;
        set v_cnt = v_cnt+10 ;
            if  v_cnt = 5000000 then leave dd;
            end if;
        end loop dd ;
end;$$
delimiter;
  • 调用存储过程

call test1;
  • 测试查询时间

select * from userta;       --3.63s

注意点

1.分表必须保证主表和子表表结构一致,否则报错
Error Code : 1168 Unable to open underlying table which is differently defined or of non-MyISAM type or doesn't exist

文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《mysql merge 分区》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表