《Mysql應(yīng)用Mysql存儲過程學(xué)習(xí)筆記--建立簡單的存儲過程》要點:
本文介紹了Mysql應(yīng)用Mysql存儲過程學(xué)習(xí)筆記--建立簡單的存儲過程,希望對您有用。如果有疑問,可以聯(lián)系我們。
一、存儲過程MYSQL數(shù)據(jù)庫
存儲過程(Stored Procedure)是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL語句集,經(jīng)編譯后存儲在數(shù)據(jù)庫中,用戶
通過指定存儲過程的名字并給出參數(shù)(如果該存儲過程帶有參數(shù))來執(zhí)行它.而我們常用的操作數(shù)據(jù)庫語言SQL語句在執(zhí)行的時
候需要要先編譯,然后執(zhí)行,所以執(zhí)行的效率沒有存儲過程高.MYSQL數(shù)據(jù)庫
存儲過程優(yōu)點如下:MYSQL數(shù)據(jù)庫
重復(fù)使用.存儲過程可以重復(fù)使用,從而可以減少數(shù)據(jù)庫開發(fā)人員的工作量.提高性能.存儲過程在創(chuàng)建的時候在進行了編譯,將來使用的時候不再重新翻譯.一般的SQL語句每執(zhí)行一次就需要編譯一次,所以使用存儲過程提高了效率.減少網(wǎng)絡(luò)流量.存儲過程位于服務(wù)器上,調(diào)用的時候只需要傳遞存儲過程的名稱以及參數(shù)就可以了,因此降低了網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)量.平安性.參數(shù)化的存儲過程可以防止SQL注入式攻擊,而且可以將Grant、Deny以及Revoke權(quán)限應(yīng)用于存儲過程.MYSQL數(shù)據(jù)庫
存儲過程簡單語法:MYSQL數(shù)據(jù)庫
CREATE PROCEDURE 存儲過程名稱( 輸入輸出類型 變量名稱 類型, 輸入輸出類型 變量名稱 類型 ) BEGIN -- 聲明, 語句要完成的操作,增刪改查... END
二、實例MYSQL數(shù)據(jù)庫
例子中的存儲過程均使用mysql作為例子.
表結(jié)構(gòu)如下:MYSQL數(shù)據(jù)庫
DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
? `id` int(11) NOT NULL AUTO_INCREMENT,
? `username` varchar(255) DEFAULT NULL,
? `age` int(11) DEFAULT NULL,
? `password` varchar(255) DEFAULT NULL,
? PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
1、只帶IN(輸入?yún)?shù))的存儲過程MYSQL數(shù)據(jù)庫
? 表示該參數(shù)的值必需在調(diào)用存儲過程時指定,在存儲過程中修改該參數(shù)的值不能被返回,為默認(rèn)值.MYSQL數(shù)據(jù)庫
DROP PROCEDURE IF EXISTS proc_person_findById;
-- 創(chuàng)建存儲過程
CREATE PROCEDURE proc_person_findById(
??? in n int
)
BEGIN
???? SELECT * FROM person where id=n;
END
-- 定義變量
SET @n=2;
-- 調(diào)用存儲過程
CALL proc_person_findById(@n);
?調(diào)用結(jié)果如下:MYSQL數(shù)據(jù)庫
MYSQL數(shù)據(jù)庫
2、只帶OUT(輸出參數(shù))的存儲過程MYSQL數(shù)據(jù)庫
該值可在存儲過程內(nèi)部被改變,并可返回.MYSQL數(shù)據(jù)庫
DROP PROCEDURE IF EXISTS proc_person_getCount
-- 創(chuàng)建存儲過程
CREATE PROCEDURE proc_person_getCount(
??? out n int(11)
)
BEGIN
???? SELECT COUNT(*) INTO n FROM person ;
END
-- 調(diào)用存儲過程
CALL proc_person_getCount(@n);
SELECT @n as '總數(shù)';
?調(diào)用結(jié)果如下:MYSQL數(shù)據(jù)庫
?MYSQL數(shù)據(jù)庫
3、帶IN(輸入?yún)?shù))和OUT(輸出參數(shù))的MYSQL數(shù)據(jù)庫
調(diào)用時指定,并且可被改變和返回MYSQL數(shù)據(jù)庫
DROP PROCEDURE IF EXISTS proc_person_findInfoById;
-- 創(chuàng)建存儲過程
CREATE PROCEDURE proc_person_findInfoById(
??? IN n INT(11),
??? OUT pusername VARCHAR(255),
??? OUT page INT(11)
)
BEGIN
???? SELECT username, age INTO pusername, page FROM person WHERE id=n;
END
-- 定義變量
SET @id=2;
-- 調(diào)用存儲過程
CALL proc_person_findInfoById(@id,@username, @age);
SELECT @username as '用戶名', @age '年齡';
?調(diào)用結(jié)果如下:MYSQL數(shù)據(jù)庫
MYSQL數(shù)據(jù)庫
4、帶INOUT(輸入輸出)參數(shù)的存儲過程MYSQL數(shù)據(jù)庫
-- 輸入輸出DROP PROCEDURE IF EXISTS proc_person_get_age;-- 創(chuàng)建存儲過程CREATE PROCEDURE proc_person_get_age( INOUT n INT(11))BEGIN SELECT age INTO N FROM person WHERE id=n;ENDSET @id = 1;CALL proc_person_get_age(@id); SELECT @id;
??調(diào)用結(jié)果如下:MYSQL數(shù)據(jù)庫
?MYSQL數(shù)據(jù)庫
5、?關(guān)于輸入輸出參數(shù)MYSQL數(shù)據(jù)庫
IN為輸入, 定義參數(shù)時,可以不加,不加則默認(rèn)為輸入?yún)?shù).OUT為輸出,定義參數(shù)時,必需加上.INOUT為輸入和輸出,必需加上.表示該參數(shù)可以輸入也可在處理后存放結(jié)果進行輸出.MYSQL數(shù)據(jù)庫
維易PHP培訓(xùn)學(xué)院每天發(fā)布《Mysql應(yīng)用Mysql存儲過程學(xué)習(xí)筆記--建立簡單的存儲過程》等實戰(zhàn)技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養(yǎng)人才。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/13652.html