在MySQL中創(chuàng)建帶有IN和OUT參數(shù)的存儲過程的方法
在 MySQL 中創(chuàng)建儲存過程的語法很難記,除非你經(jīng)常跟儲存過程打交道,原因很簡單,語法不是什么小笑話。如果你通過命令行控制 MySQL,你需要記住準確的語法。一個快速示例可以很好的幫助你做到這點。在MySQL 入門教程中,我們能夠看到很多關于如何創(chuàng)建儲存過程 和如何利用 IN 和 OUT 參數(shù)調(diào)用存儲過程的示例。這些示例都很簡單,能夠很好的幫助你理解 MySQL 中創(chuàng)建帶參數(shù)存儲過程的語法。這些示例已在 MySQL 5.5 中通過測試。我們將用下面的雇員表創(chuàng)建并測試這些儲存過程:
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)
下面是一個命令行方式創(chuàng)建MySQL存過的例子,我們根據(jù) department從employee表中獲取一個總數(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 ;
首先我們改變默認的分隔符為“//”來作為存儲過程結束的標識,隨后再恢復默認值。使用“usp”前綴是區(qū)分系統(tǒng)存過過程和用戶自定義存儲過程的最佳實踐。現(xiàn)在你可以在MySQL命令行像這樣來調(diào)用存過:
mysql> call usp_totalEmployeeByDeparment(2); +-------+ | total | +-------+ | 1 | +-------+ 1 row in set (0.06 sec)
創(chuàng)建和使用帶IN和OUT參數(shù)的存儲過程
在這個MySQL例子中,我們創(chuàng)建了一個IN和一個OUT參數(shù)的存儲過程 usp_GetEmployeeName。當調(diào)用這個存儲過程時,你需要傳遞2個參數(shù):id和name,一個作為輸入?yún)?shù)id,另外一個作為輸出參數(shù)返回結果。
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)用存過: mysql> select @name; +-------+ | @name | +-------+ | Jack | +-------+ 1 row in set (0.00 sec)
這就是怎樣從命令行方式創(chuàng)建和調(diào)用存儲過程的所有內(nèi)容,在這個教程中,我們創(chuàng)建了帶IN和OUT參數(shù)的存儲過程多個例子。這是記住MySQL數(shù)據(jù)庫存過語法的最好方式。
- 詳解MySQL存儲過程的創(chuàng)建和調(diào)用
- mysql創(chuàng)建存儲過程及函數(shù)詳解
- MySQL之存儲過程按月創(chuàng)建表的方法步驟
- mysql創(chuàng)建存儲過程實現(xiàn)往數(shù)據(jù)表中新增字段的方法分析
- MySQL實現(xiàn)創(chuàng)建存儲過程并循環(huán)添加記錄的方法
- 深入mysql創(chuàng)建自定義函數(shù)與存儲過程的詳解
- MySQL動態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲過程
- MySQL5創(chuàng)建存儲過程的示例
- 查看MySQL中已經(jīng)創(chuàng)建的存儲過程及其定義
相關文章
MySQL 實現(xiàn)樹的遍歷詳解及簡單實現(xiàn)示例
這篇文章主要介紹了MySQL 實現(xiàn)樹的遍歷詳解及簡單實現(xiàn)示例的相關資料,這里提供了示例代碼及測試結果,需要的朋友可以參考下2017-01-01
詳解監(jiān)聽MySQL的binlog日志工具分析:Canal
Canal主要用途是基于MySQL數(shù)據(jù)庫增量日志解析,提供增量數(shù)據(jù)訂閱和消費,目前主要支持MySQL。接下來通過本文給大家介紹監(jiān)聽MySQL的binlog日志工具分析:Canal的相關知識,感興趣的朋友一起看看吧2020-10-10
解決hibernate+mysql寫入數(shù)據(jù)庫亂碼
初次沒習hibernate,其中遇到問題在網(wǎng)上找的答案與大家共同分享!2009-07-07
解決mysql報錯:Data?source?rejected?establishment?of?connect
這篇文章主要給大家介紹了關于如何解決mysql報錯:Data?source?rejected?establishment?of?connection,?message?from?server:?\"Too?many?connectio的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02
MySQL里Create Index 能否創(chuàng)建主鍵 Primary Key
MySQL里Create Index 能否創(chuàng)建主鍵 Primary Key2009-07-07

