欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2014年08月13日 09:32:36   投稿:hebedich  
我們常用的操作數(shù)據(jù)庫(kù)語言SQL語句在執(zhí)行的時(shí)候需要要先編譯,然后執(zhí)行,而存儲(chǔ)過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經(jīng)編譯后存儲(chǔ)在數(shù)據(jù)庫(kù)中,用戶通過指定存儲(chǔ)過程的名字并給定參數(shù)(如果該存儲(chǔ)過程帶有參數(shù))來調(diào)用執(zhí)行它。

一、存儲(chǔ)過程

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

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

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

  存儲(chǔ)過程簡(jiǎn)單語法:

CREATE PROCEDURE 存儲(chǔ)過程名稱(
  輸入輸出類型 變量名稱 類型,

    輸入輸出類型 變量名稱 類型

)
BEGIN
  -- 聲明, 語句要完成的操作,增刪改查。。。
END

二、實(shí)例

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

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

DROP PROCEDURE IF EXISTS proc_person_findById;
-- 創(chuàng)建存儲(chǔ)過程
CREATE PROCEDURE proc_person_findById(
    in n int
)
BEGIN
     SELECT * FROM person where id=n;
END
-- 定義變量
SET @n=2;
-- 調(diào)用存儲(chǔ)過程
CALL proc_person_findById(@n);

 調(diào)用結(jié)果如下:

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

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

DROP PROCEDURE IF EXISTS proc_person_getCount
-- 創(chuàng)建存儲(chǔ)過程
CREATE PROCEDURE proc_person_getCount(
    out n int(11)
)
BEGIN
     SELECT COUNT(*) INTO n FROM person ;
END
-- 調(diào)用存儲(chǔ)過程
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ǔ)過程
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ǔ)過程
CALL proc_person_findInfoById(@id,@username, @age);
SELECT @username as '用戶名', @age '年齡';

 調(diào)用結(jié)果如下:

  

  4、帶INOUT(輸入輸出)參數(shù)的存儲(chǔ)過程

-- 輸入輸出DROP PROCEDURE IF EXISTS proc_person_get_age;-- 創(chuàng)建存儲(chǔ)過程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)行輸出。

相關(guān)文章

  • mysql 5.6 從陌生到熟練之_數(shù)據(jù)庫(kù)備份恢復(fù)的實(shí)現(xiàn)方法

    mysql 5.6 從陌生到熟練之_數(shù)據(jù)庫(kù)備份恢復(fù)的實(shí)現(xiàn)方法

    下面小編就為大家?guī)硪黄猰ysql 5.6 從陌生到熟練之_數(shù)據(jù)庫(kù)備份恢復(fù)的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-10-10
  • Mysql存儲(chǔ)過程、觸發(fā)器、事件調(diào)度器使用入門指南

    Mysql存儲(chǔ)過程、觸發(fā)器、事件調(diào)度器使用入門指南

    存儲(chǔ)過程(Stored Procedure)是一種在數(shù)據(jù)庫(kù)中存儲(chǔ)復(fù)雜程序的數(shù)據(jù)庫(kù)對(duì)象。為了完成特定功能的SQL語句集,經(jīng)過編譯創(chuàng)建并保存在數(shù)據(jù)庫(kù)中,本文給大家介紹Mysql存儲(chǔ)過程、觸發(fā)器、事件調(diào)度器使用入門指南,感興趣的朋友一起看看吧
    2022-01-01
  • mysql實(shí)現(xiàn)不用密碼登錄的實(shí)例方法

    mysql實(shí)現(xiàn)不用密碼登錄的實(shí)例方法

    在本篇文章里小編給大家整理的是一篇關(guān)于mysql實(shí)現(xiàn)不用密碼登錄的實(shí)例方法,有需要的朋友們可以學(xué)習(xí)參考下。
    2020-08-08
  • 使用limit,offset分頁(yè)場(chǎng)景時(shí)為什么會(huì)慢

    使用limit,offset分頁(yè)場(chǎng)景時(shí)為什么會(huì)慢

    這篇文章主要介紹了使用limit,offset分頁(yè)場(chǎng)景時(shí)為什么會(huì)慢,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • MySQL 按指定字段自定義列表排序的實(shí)現(xiàn)

    MySQL 按指定字段自定義列表排序的實(shí)現(xiàn)

    下面小編就為大家?guī)硪黄狹ySQL 按指定字段自定義列表排序的實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • mysql 表空間及索引的查看方法

    mysql 表空間及索引的查看方法

    mysql 表空間及索引的查看方法,需要的朋友可以參考下。
    2011-07-07
  • MySQL導(dǎo)入與導(dǎo)出備份詳解

    MySQL導(dǎo)入與導(dǎo)出備份詳解

    大家好,本篇文章主要講的是MySQL導(dǎo)入與導(dǎo)出備份詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 提高M(jìn)ySQL深分頁(yè)查詢效率的三種方案

    提高M(jìn)ySQL深分頁(yè)查詢效率的三種方案

    這篇文章介紹了提高M(jìn)ySQL深分頁(yè)查詢效率的三種方案,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • MySQL 日期格式化的使用示例

    MySQL 日期格式化的使用示例

    在MySQL中,可以使用DATE_FORMAT函數(shù)對(duì)日期進(jìn)行格式化,本文就來介紹一下MySQL 日期格式化的使用示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • 源碼編譯安裝MySQL8.0.20的詳細(xì)教程

    源碼編譯安裝MySQL8.0.20的詳細(xì)教程

    這篇文章主要介紹了源碼編譯安裝MySQL8.0.20的詳細(xì)教程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05

最新評(píng)論