Mysql存儲過程代碼例子

jopen 9年前發布 | 1K 次閱讀 SQL MySQL

--定義一個新的命令結束符號,默認的是以;為結束標記
--同樣的可以通過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 ;</pre>


--修改語句定界符為$$
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);



 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!