年终大学习之MySQL数据库优化学习笔记(四)

    生活慢慢的变的有规律,这是好事,不能像前几天各种颓废了,不管怎么样坚持一天或两天写一篇博客吧,嘿嘿,然后就是每天坚持学一点东西,不然到了学校坑爹的流量就不能看教学视频了,唉。。。

    说主题,今天讨论的是如何构建一个合理的测试用的百万级大表。

    为了测试定位慢查询,我们是不能构建一个单一的表,即所有的记录应该是有不同的,不然测试得出的数据就很不可靠。

    首先,构建一个数据库;

create database low_test;
   然后构建表,我们以公司员工数据库为模板来构建;

use low_test;

CREATE TABLE dept
( /*部门表*/
    deptno MEDIUMINT   UNSIGNED  NOT NULL  DEFAULT 0, 
    dname VARCHAR(20)  NOT NULL  DEFAULT "",
    loc VARCHAR(13) NOT NULL DEFAULT ""
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

#创建表EMP雇员
CREATE TABLE emp
(
 empno  MEDIUMINT UNSIGNED  NOT NULL  DEFAULT 0, /*编号*/
 ename VARCHAR(20) NOT NULL DEFAULT "", /*名字*/
 job VARCHAR(9) NOT NULL DEFAULT "",/*工作*/
 mgr MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,/*上级编号*/
 hiredate DATE NOT NULL,/*入职时间*/
 sal DECIMAL(7,2)  NOT NULL,/*薪水*/
 comm DECIMAL(7,2) NOT NULL,/*红利*/
 deptno MEDIUMINT UNSIGNED NOT NULL DEFAULT 0 /*部门编号*/
)ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

#工资级别表
CREATE TABLE salgrade
(
 grade MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,
 losal DECIMAL(17,2)  NOT NULL,
 hisal DECIMAL(17,2)  NOT NULL
)ENGINE=MyISAM DEFAULT CHARSET=utf8;

      为了满足第三范式,我们还需要定义工资级别,如下:

INSERT INTO salgrade VALUES (1,700,1200);
INSERT INTO salgrade VALUES (2,1201,1400);
INSERT INTO salgrade VALUES (3,1401,2000);
INSERT INTO salgrade VALUES (4,2001,3000);
INSERT INTO salgrade VALUES (5,3001,9999);

    为了让每个记录有不同,特地的自定义了两个函数,方便存储过程来使用

delimiter $$

#删除自定的函数
drop  function rand_string $$

#rand_string(n INT) rand_string 是函数名 (n INT) //该函数接收一个整数
create function rand_string(n INT) 
returns varchar(255) #该函数会返回一个字符串
begin 
#chars_str定义一个变量 chars_str,类型是 varchar(100),默认值'abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ';
 declare chars_str varchar(100) default
   'abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ';
 declare return_str varchar(255) default '';
 declare i int default 0;
 while i < n do 
   set return_str =concat(return_str,substring(chars_str,floor(1+rand()*52),1));
   set i = i + 1;
   end while;
  return return_str;
  end $$

delimiter ;

    这里特别提醒,delimiter 这个关键字只能在命令行中使用,在图形客户端中使用是会报错的,不要问我为什么。。。没有深究。

    再定义一个随机数的:

# 随机产生部门编号
delimiter $$
drop  function rand_num $$

#这里我们又自定了一个函数
create function rand_num( )
returns int(5)
begin 
 declare i int default 0;
 set i = floor(10+rand()*500);
return i;
  end $$


delimiter ;

     再添加海量的数据:

#向emp表中插入记录(海量的数据)


delimiter $$
drop procedure insert_emp $$


#随即添加雇员[光标]  400w
create procedure insert_emp(in start int(10),in max_num int(10))
begin
declare i int default 0; 
#set autocommit =0 把autocommit设置成0
 set autocommit = 0;  
 repeat
 set i = i + 1;
 insert into emp values ((start+i) ,rand_string(6),'SALESMAN',0001,curdate(),2000,400,rand_num());
  until i = max_num
 end repeat;
   commit;
 end $$


delimiter ;
#调用刚刚写好的函数, 1800000条记录,从100001号开始
call insert_emp(100001,4000000);

以上构建表的程序都是来自传智博客的学习资料,仅作学习笔记记录所用。。。。






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值