国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

Mysql存儲(chǔ)過(guò)程學(xué)習(xí)筆記--建立簡(jiǎn)單的存儲(chǔ)過(guò)程

2020-01-18 23:07:54
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

一、存儲(chǔ)過(guò)程

  存儲(chǔ)過(guò)程(Stored Procedure)是在大型數(shù)據(jù)庫(kù)系統(tǒng)中,一組為了完成特定功能的SQL語(yǔ)句集,經(jīng)編譯后存儲(chǔ)在數(shù)據(jù)庫(kù)中,用戶(hù)
通過(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ò)程的名稱(chēng)以及參數(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ò)程名稱(chēng)(  輸入輸出類(lèi)型 變量名稱(chēng) 類(lèi)型,    輸入輸出類(lèi)型 變量名稱(chēng) 類(lèi)型)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 '用戶(hù)名', @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)行輸出。

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 获嘉县| 新巴尔虎左旗| 射洪县| 招远市| 田东县| 湖南省| 罗定市| 浦东新区| 溆浦县| 且末县| 阿拉善盟| 鹤山市| 三亚市| 沙田区| 临猗县| 留坝县| 梓潼县| 讷河市| 湖南省| 三门县| 奎屯市| 恩施市| 同仁县| 扬中市| 广州市| 静安区| 平和县| 邓州市| 诏安县| 阳曲县| 靖边县| 延津县| 乐陵市| 吉水县| 温宿县| 额济纳旗| 肥东县| 大洼县| 饶阳县| 渝中区| 荆门市|