本文實(shí)例講述了mysql存儲過程用法。分享給大家供大家參考,具體如下:
概述:
簡單的說,就是一組SQL語句集,功能強(qiáng)大,可以實(shí)現(xiàn)一些比較復(fù)雜的邏輯功能,類似于JAVA語言中的方法;
存儲過程跟觸發(fā)器有點(diǎn)類似,都是一組SQL集,但是存儲過程是主動調(diào)用的,且功能比觸發(fā)器更加強(qiáng)大,觸發(fā)器是某件事觸發(fā)后自動調(diào)用;
示例
DELIMITER //
CREATE PROCEDURE proc (IN num INT)
BEGIN
SELECT * FROM v9_qd_account limit num;
END //
DELIMITER ;
執(zhí)行:
SET @p_in=5;
CALL proc(@p_in);
或者
循環(huán)
DECLARE num int default 5;
SET num = 1;
SET num = num + 1;
DELIMITER //
CREATE PROCEDURE proc(IN sname VARCHAR(20),IN pwd VARCHAR(5),IN qd INT,IN start INT,IN end INT)
begin
DECLARE var INT;
DECLARE myname VARCHAR(30);
SET var=start;
while varend do
SET myname = CONCAT(sname,LPAD(var,3,'0'));
insert into v9_qd_account (storename,password,qudao,regdate) value(myname,md5(pwd),qd,UNIX_TIMESTAMP());
SET var=var+1;
end while;
end //
DELIMITER ;
調(diào)用
CALL proc('test','123456',1,1,21);
查看
SHOW PROCEDURE STATUS LIKE 'C%' \G; 查看以字母C開頭的存儲過程
SHOW CREATE PROCEDURE proc \G; 查看狀態(tài)和創(chuàng)建語句
information_schema.Routines 中查看
刪除
DROP PROCEDURE IF EXISTS proc;
DROP FUNCTION mytest;
點(diǎn)撥
如果參數(shù)中有中文可以這樣
CREATE PROCEDURE useInfo(IN u_name VARCHAR(50) character set gbk,OUT u_age INT) ......
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL存儲過程技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計(jì)有所幫助。
您可能感興趣的文章:- mysql 存儲過程中變量的定義與賦值操作
- mysql存儲過程詳解
- mysql存儲過程 游標(biāo) 循環(huán)使用介紹
- MySQL存儲過程例子(包含事務(wù),輸出參數(shù),嵌套調(diào)用)
- MySql存儲過程與函數(shù)詳解
- mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句
- MySQL 有輸入輸出參數(shù)的存儲過程實(shí)例
- 實(shí)例解析MySQL中的存儲過程及存儲過程的調(diào)用方法
- Mysql存儲過程和函數(shù)區(qū)別介紹
- MySQL 存儲過程中執(zhí)行動態(tài)SQL語句的方法
- mysql存儲過程中使用游標(biāo)的實(shí)例
- Mysql存儲過程循環(huán)內(nèi)嵌套使用游標(biāo)示例代碼