在MySQL中創(chuàng)建帶有IN和OUT參數(shù)的存儲(chǔ)過(guò)程的方法
在 MySQL 中創(chuàng)建儲(chǔ)存過(guò)程的語(yǔ)法很難記,除非你經(jīng)常跟儲(chǔ)存過(guò)程打交道,原因很簡(jiǎn)單,語(yǔ)法不是什么小笑話(huà)。如果你通過(guò)命令行控制 MySQL,你需要記住準(zhǔn)確的語(yǔ)法。一個(gè)快速示例可以很好的幫助你做到這點(diǎn)。在MySQL 入門(mén)教程中,我們能夠看到很多關(guān)于如何創(chuàng)建儲(chǔ)存過(guò)程 和如何利用 IN 和 OUT 參數(shù)調(diào)用存儲(chǔ)過(guò)程的示例。這些示例都很簡(jiǎn)單,能夠很好的幫助你理解 MySQL 中創(chuàng)建帶參數(shù)存儲(chǔ)過(guò)程的語(yǔ)法。這些示例已在 MySQL 5.5 中通過(guò)測(cè)試。我們將用下面的雇員表創(chuàng)建并測(cè)試這些儲(chǔ)存過(guò)程:
mysql> select * from employee; +--------+----------+---------+--------+ | emp_id | emp_name | dept_id | salary | +--------+----------+---------+--------+ | 103 | Jack | 1 | 1400 | | 104 | John | 2 | 1450 | | 108 | Alan | 3 | 1150 | | 107 | Ram | NULL | 600 | +--------+----------+---------+--------+ 4 rows in set (0.22 sec)
下面是一個(gè)命令行方式創(chuàng)建MySQL存過(guò)的例子,我們根據(jù) department從employee表中獲取一個(gè)總數(shù),dept_id是department表的 外鍵。
mysql> DELIMITER // mysql> create procedure usp_totalEmployeeByDeparment(IN id INT) -> begin -> select count(*) as total from employee where dept_id = id; -> end// Query OK, 0 rows affected (0.00 sec)
mysql> DELIMITER ;
首先我們改變默認(rèn)的分隔符為“//”來(lái)作為存儲(chǔ)過(guò)程結(jié)束的標(biāo)識(shí),隨后再恢復(fù)默認(rèn)值。使用“usp”前綴是區(qū)分系統(tǒng)存過(guò)過(guò)程和用戶(hù)自定義存儲(chǔ)過(guò)程的最佳實(shí)踐。現(xiàn)在你可以在MySQL命令行像這樣來(lái)調(diào)用存過(guò):
mysql> call usp_totalEmployeeByDeparment(2); +-------+ | total | +-------+ | 1 | +-------+ 1 row in set (0.06 sec)
創(chuàng)建和使用帶IN和OUT參數(shù)的存儲(chǔ)過(guò)程
在這個(gè)MySQL例子中,我們創(chuàng)建了一個(gè)IN和一個(gè)OUT參數(shù)的存儲(chǔ)過(guò)程 usp_GetEmployeeName。當(dāng)調(diào)用這個(gè)存儲(chǔ)過(guò)程時(shí),你需要傳遞2個(gè)參數(shù):id和name,一個(gè)作為輸入?yún)?shù)id,另外一個(gè)作為輸出參數(shù)返回結(jié)果。
mysql> DELIMITER // mysql> create procedure usp_GetEmployeeName(IN id INT, OUT name VARCHAR(20)) -> begin -> select emp_name into name from employee where emp_id = id; -> end// Query OK, 0 rows affected (0.52 sec) mysql> DELIMITER ; mysql> call usp_GetEmployeeName(103, @name); Query OK, 1 row affected (0.05 sec) 以MySQL命令行方式調(diào)用存過(guò): mysql> select @name; +-------+ | @name | +-------+ | Jack | +-------+ 1 row in set (0.00 sec)
這就是怎樣從命令行方式創(chuàng)建和調(diào)用存儲(chǔ)過(guò)程的所有內(nèi)容,在這個(gè)教程中,我們創(chuàng)建了帶IN和OUT參數(shù)的存儲(chǔ)過(guò)程多個(gè)例子。這是記住MySQL數(shù)據(jù)庫(kù)存過(guò)語(yǔ)法的最好方式。
- 詳解MySQL存儲(chǔ)過(guò)程的創(chuàng)建和調(diào)用
- mysql創(chuàng)建存儲(chǔ)過(guò)程及函數(shù)詳解
- MySQL之存儲(chǔ)過(guò)程按月創(chuàng)建表的方法步驟
- mysql創(chuàng)建存儲(chǔ)過(guò)程實(shí)現(xiàn)往數(shù)據(jù)表中新增字段的方法分析
- MySQL實(shí)現(xiàn)創(chuàng)建存儲(chǔ)過(guò)程并循環(huán)添加記錄的方法
- 深入mysql創(chuàng)建自定義函數(shù)與存儲(chǔ)過(guò)程的詳解
- MySQL動(dòng)態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲(chǔ)過(guò)程
- MySQL5創(chuàng)建存儲(chǔ)過(guò)程的示例
- 查看MySQL中已經(jīng)創(chuàng)建的存儲(chǔ)過(guò)程及其定義
相關(guān)文章
學(xué)習(xí)mysql之后的一點(diǎn)總結(jié)(基礎(chǔ))
學(xué)習(xí)mysql之后的一點(diǎn)總結(jié),比較適合新手朋友2012-05-05對(duì)MySQL中字符集的相關(guān)設(shè)置操作的基本教程
這篇文章主要介紹了對(duì)MySQL中字符集的相關(guān)設(shè)置操作的基本教程,重點(diǎn)講解了修改MySQL字符集的方法,需要的朋友可以參考下2015-12-12mysql設(shè)置更改root密碼、mysql服務(wù)器的連接、mysql常用命令的圖解
這篇文章主要介紹了mysql設(shè)置更改root密碼、mysql服務(wù)器的連接、mysql常用命令,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06MySQL 隨機(jī)函數(shù)獲取數(shù)據(jù)速度和效率分析
最近做項(xiàng)目,需要做一個(gè)從mysql數(shù)據(jù)庫(kù)中隨機(jī)取幾條數(shù)據(jù)出來(lái)。總所周知,order by rand 會(huì)死人的。。因?yàn)楸救藢?duì)大數(shù)據(jù)量方面的只是了解的很少,無(wú)解,去找百度老師。。搜索結(jié)果千篇一律。特發(fā)到這里來(lái),供大家學(xué)習(xí),需要的朋友可以參考下2016-11-11Can’t open file:''[Table]mytable.MYI''
也許很多人遇到過(guò)類(lèi)似Can’t open file: ‘[Table]mytable.MYI’ 這樣的錯(cuò)誤信息,卻不知道怎么解決他,下面我們做個(gè)介紹,2011-01-01mysql表分區(qū)的方式和實(shí)現(xiàn)代碼示例
通俗地講表分區(qū)是將一個(gè)大表,根據(jù)條件分割成若干個(gè)小表,下面這篇文章主要給大家介紹了關(guān)于mysql表分區(qū)的方式和實(shí)現(xiàn)代碼,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02mysql查詢(xún)昨天 一周前 一月前 一年前的數(shù)據(jù)
這篇文章主要介紹了mysql查詢(xún)昨天 一周前 一月前 一年前的數(shù)據(jù)的方法,需要的朋友可以參考下2014-05-05