加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql存储过程代码例子

发布时间:2021-01-10 10:16:51 所属栏目:MySql教程 来源:网络整理
导读:以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 --定义一个新的命令结束符号,默认的是以;为结束标记--同样的可以通过delimiter ;再设置;为结束标记delimiter $$--删除函数rand_stringdrop function rand_string $$-

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

--定义一个新的命令结束符号,默认的是以;为结束标记
--同样的可以通过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);

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读