Mysql存儲(chǔ)過(guò)程學(xué)習(xí)筆記--建立簡(jiǎn)單的存儲(chǔ)過(guò)程
一、存儲(chǔ)過(guò)程
存儲(chǔ)過(guò)程(Stored Procedure)是在大型數(shù)據(jù)庫(kù)系統(tǒng)中,一組為了完成特定功能的SQL語(yǔ)句集,經(jīng)編譯后存儲(chǔ)在數(shù)據(jù)庫(kù)中,用戶
通過(guò)指定存儲(chǔ)過(guò)程的名字并給出參數(shù)(如果該存儲(chǔ)過(guò)程帶有參數(shù))來(lái)執(zhí)行它。而我們常用的操作數(shù)據(jù)庫(kù)語(yǔ)言SQL語(yǔ)句在執(zhí)行的時(shí)
候需要要先編譯,然后執(zhí)行,所以執(zhí)行的效率沒(méi)有存儲(chǔ)過(guò)程高。
存儲(chǔ)過(guò)程優(yōu)點(diǎn)如下:
重復(fù)使用。存儲(chǔ)過(guò)程可以重復(fù)使用,從而可以減少數(shù)據(jù)庫(kù)開(kāi)發(fā)人員的工作量。提高性能。存儲(chǔ)過(guò)程在創(chuàng)建的時(shí)候在進(jìn)行了編譯,將來(lái)使用的時(shí)候不再重新翻譯。一般的SQL語(yǔ)句每執(zhí)行一次就需要編譯一次,所以使用存儲(chǔ)過(guò)程提高了效率。減少網(wǎng)絡(luò)流量。存儲(chǔ)過(guò)程位于服務(wù)器上,調(diào)用的時(shí)候只需要傳遞存儲(chǔ)過(guò)程的名稱以及參數(shù)就可以了,因此降低了網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)量。安全性。參數(shù)化的存儲(chǔ)過(guò)程可以防止SQL注入式攻擊,而且可以將Grant、Deny以及Revoke權(quán)限應(yīng)用于存儲(chǔ)過(guò)程。
存儲(chǔ)過(guò)程簡(jiǎn)單語(yǔ)法:
CREATE PROCEDURE 存儲(chǔ)過(guò)程名稱( 輸入輸出類型 變量名稱 類型, 輸入輸出類型 變量名稱 類型 ) BEGIN -- 聲明, 語(yǔ)句要完成的操作,增刪改查。。。 END
二、實(shí)例
例子中的存儲(chǔ)過(guò)程均使用mysql作為例子。
表結(jié)構(gòu)如下:
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ù))的存儲(chǔ)過(guò)程
表示該參數(shù)的值必須在調(diào)用存儲(chǔ)過(guò)程時(shí)指定,在存儲(chǔ)過(guò)程中修改該參數(shù)的值不能被返回,為默認(rèn)值.
DROP PROCEDURE IF EXISTS proc_person_findById;
-- 創(chuàng)建存儲(chǔ)過(guò)程
CREATE PROCEDURE proc_person_findById(
in n int
)
BEGIN
SELECT * FROM person where id=n;
END
-- 定義變量
SET @n=2;
-- 調(diào)用存儲(chǔ)過(guò)程
CALL proc_person_findById(@n);
調(diào)用結(jié)果如下:

2、只帶OUT(輸出參數(shù))的存儲(chǔ)過(guò)程
該值可在存儲(chǔ)過(guò)程內(nèi)部被改變,并可返回。
DROP PROCEDURE IF EXISTS proc_person_getCount
-- 創(chuàng)建存儲(chǔ)過(guò)程
CREATE PROCEDURE proc_person_getCount(
out n int(11)
)
BEGIN
SELECT COUNT(*) INTO n FROM person ;
END
-- 調(diào)用存儲(chǔ)過(guò)程
CALL proc_person_getCount(@n);
SELECT @n as '總數(shù)';
調(diào)用結(jié)果如下:

3、帶IN(輸入?yún)?shù))和OUT(輸出參數(shù))的
調(diào)用時(shí)指定,并且可被改變和返回
DROP PROCEDURE IF EXISTS proc_person_findInfoById;
-- 創(chuàng)建存儲(chǔ)過(guò)程
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)用存儲(chǔ)過(guò)程
CALL proc_person_findInfoById(@id,@username, @age);
SELECT @username as '用戶名', @age '年齡';
調(diào)用結(jié)果如下:
4、帶INOUT(輸入輸出)參數(shù)的存儲(chǔ)過(guò)程
-- 輸入輸出DROP PROCEDURE IF EXISTS proc_person_get_age;-- 創(chuàng)建存儲(chǔ)過(guò)程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é)果如下:

5、 關(guān)于輸入輸出參數(shù)
IN為輸入, 定義參數(shù)時(shí),可以不加,不加則默認(rèn)為輸入?yún)?shù)。OUT為輸出,定義參數(shù)時(shí),必須加上。INOUT為輸入和輸出,必須加上。表示該參數(shù)可以輸入也可在處理后存放結(jié)果進(jìn)行輸出。
- Mysql存儲(chǔ)過(guò)程循環(huán)內(nèi)嵌套使用游標(biāo)示例代碼
- mysql 存儲(chǔ)過(guò)程輸入輸出參數(shù)示例
- MySQL 存儲(chǔ)過(guò)程中執(zhí)行動(dòng)態(tài)SQL語(yǔ)句的方法
- Node.js中調(diào)用mysql存儲(chǔ)過(guò)程示例
- PHP調(diào)用MySQL存儲(chǔ)過(guò)程并返回值的方法
- php調(diào)用mysql存儲(chǔ)過(guò)程實(shí)例分析
- Java調(diào)用MySQL存儲(chǔ)過(guò)程并獲得返回值的方法
- MySql存儲(chǔ)過(guò)程之邏輯判斷和條件控制
相關(guān)文章
淺析centos 7 mysql-8.0.19-1.el7.x86_64.rpm-bundle.tar
這篇文章主要介紹了centos 7 mysql-8.0.19-1.el7.x86_64.rpm-bundle.tar的相關(guān)知識(shí),需要的朋友可以參考下2020-01-01
MySQL異?;謴?fù)之無(wú)主鍵情況下innodb數(shù)據(jù)恢復(fù)的方法
這篇文章主要介紹了MySQL異?;謴?fù)之無(wú)主鍵情況下innodb數(shù)據(jù)恢復(fù)的方法,結(jié)合實(shí)例形式分析了針對(duì)innodb引擎無(wú)主鍵的情況下恢復(fù)數(shù)據(jù)的步驟與相關(guān)技巧,需要的朋友可以參考下2016-04-04
MySQL中dd::columns表結(jié)構(gòu)轉(zhuǎn)table過(guò)程及應(yīng)用詳解
MySQL的dd表是用來(lái)存放表結(jié)構(gòu)和各種建表信息的,客戶端建的表都存在mysql.table和mysql.columns表里,還有一個(gè)表mysql.column_type_elements比較特殊,用來(lái)存放SET和ENUM類型的字段集合值信息,對(duì)mysql dd::columns表結(jié)構(gòu)相關(guān)知識(shí)感興趣的朋友一起看看吧2022-09-09
mysql數(shù)據(jù)庫(kù)基礎(chǔ)知識(shí)點(diǎn)與操作小結(jié)
這篇文章主要介紹了mysql數(shù)據(jù)庫(kù)基礎(chǔ)知識(shí)點(diǎn)與操作,總結(jié)分析了mysql數(shù)據(jù)庫(kù)修改數(shù)據(jù)表、增刪改查及數(shù)據(jù)庫(kù)函數(shù)基本功能,需要的朋友可以參考下2020-01-01
Mysql的timestamp時(shí)間戳詳解及2038問(wèn)題
本文主要介紹了Mysql的timestamp時(shí)間戳詳解及2038問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
MySQL中crash safe數(shù)據(jù)完整性機(jī)制面試精講
這篇文章主要為大家介紹了MySQL數(shù)據(jù)完整性crash safe特性面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10

