- --定义一个新的命令结束符号,默认的是以;为结束标记
- --同样的可以通过delimiter ;再设置;为结束标记
- delimiter $$
- --删除函数rand_string
- drop function rand_string $$
- --创建函数rand_string(n):随机产生n个字符组成的字符串
- create function rand_string(n INT)
- returns varchar(255)
- begin
- declare chars_str varchar(100)default 'abcefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
- declare return_str varchar(255) default '';
- declare i int default 0;
- while i < n do
- --concat('a','b'):ab
- --substring(str,pos,len):得到字符串str从pos位置开始长度为len的字符串
- --rand():得到一个[0,1]的随机小数
- 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 $$
- --自定义函数rand_num():随机生成一个整数
- create function rand_num()
- returns int(5)
- begin
- declare i int defaule 0;
- set i = floor(10 + rand() * 50);
- return i;
- end $$
- --修改语句定界符为;
- delimiter ;
- --修改语句定界符为$$
- delimiter $$
- --创建一个存储过程
- create procedure insert_emp(in start int(10), in max_num int(10))
- begin
- declare i int default 0;
- set autocommit = 0;
- repeat
- set i = i + 1;
- insert into emp values(start + i, rand_string(6), 'SALESMAN'.0001,curdate(), 2000);
- until i = max_num
- end repeat;
- commit;
- end $$
- --修改语句定界符为;
- delimiter ;
- --调用存储过程
- call inert_emp(100001, 4800000);
来源: http://www.phpxs.com/code/1005318/