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

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

Mysql存儲過程學(xué)習(xí)筆記--建立簡單的存儲過程

2024-07-24 12:46:48
字體:
供稿:網(wǎng)友

一、存儲過程

  存儲過程(Stored Procedure)是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL語句集,經(jīng)編譯后存儲在數(shù)據(jù)庫中,用戶
通過指定存儲過程的名字并給出參數(shù)(如果該存儲過程帶有參數(shù))來執(zhí)行它。而我們常用的操作數(shù)據(jù)庫語言SQL語句在執(zhí)行的時
候需要要先編譯,然后執(zhí)行,所以執(zhí)行的效率沒有存儲過程高。

  存儲過程優(yōu)點(diǎn)如下:

重復(fù)使用。存儲過程可以重復(fù)使用,從而可以減少數(shù)據(jù)庫開發(fā)人員的工作量。提高性能。存儲過程在創(chuàng)建的時候在進(jìn)行了編譯,將來使用的時候不再重新翻譯。一般的SQL語句每執(zhí)行一次就需要編譯一次,所以使用存儲過程提高了效率。減少網(wǎng)絡(luò)流量。存儲過程位于服務(wù)器上,調(diào)用的時候只需要傳遞存儲過程的名稱以及參數(shù)就可以了,因此降低了網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)量。安全性。參數(shù)化的存儲過程可以防止SQL注入式攻擊,而且可以將Grant、Deny以及Revoke權(quán)限應(yīng)用于存儲過程。

  存儲過程簡單語法:

CREATE PROCEDURE 存儲過程名稱(  輸入輸出類型 變量名稱 類型,    輸入輸出類型 變量名稱 類型)BEGIN  -- 聲明, 語句要完成的操作,增刪改查。。。END

二、實(shí)例

  例子中的存儲過程均使用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ù))的存儲過程

   表示該參數(shù)的值必須在調(diào)用存儲過程時指定,在存儲過程中修改該參數(shù)的值不能被返回,為默認(rèn)值.

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é)果如下:

  2、只帶OUT(輸出參數(shù))的存儲過程

  該值可在存儲過程內(nèi)部被改變,并可返回。

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);
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 五家渠市| 梧州市| 湘西| 绥滨县| 穆棱市| 上杭县| 大厂| 贺州市| 乌鲁木齐市| 阿拉尔市| 拜泉县| 资阳市| 富裕县| 新邵县| 华安县| 张家港市| 泉州市| 永清县| 永年县| 吉首市| 噶尔县| 来凤县| 丹东市| 正定县| 布尔津县| 海宁市| 华蓥市| 镇原县| 延寿县| 兰西县| 舟山市| 中方县| 磴口县| 疏附县| 沽源县| 渝北区| 泾川县| 云龙县| 西宁市| 浦城县| 嘉定区|