MySQL存儲(chǔ)過(guò)程的異常處理方法
本文實(shí)例講述了MySQL存儲(chǔ)過(guò)程的異常處理方法。分享給大家供大家參考。具體如下:
mysql>
mysql> delimiter $$
mysql>
mysql> CREATE PROCEDURE myProc
-> (p_first_name VARCHAR(30),
-> p_last_name VARCHAR(30),
-> p_city VARCHAR(30),
-> p_description VARCHAR(30),
-> OUT p_sqlcode INT,
-> OUT p_status_message VARCHAR(100))
-> BEGIN
->
-> /* START Declare Conditions */
->
-> DECLARE duplicate_key CONDITION FOR 1062;
-> DECLARE foreign_key_violated CONDITION FOR 1216;
->
-> /* END Declare Conditions */
->
-> /* START Declare variables and cursors */
->
-> DECLARE l_manager_id INT;
->
-> DECLARE csr_mgr_id CURSOR FOR
-> SELECT id
-> FROM employee
-> WHERE first_name=p_first_name
-> AND last_name=p_last_name;
->
-> /* END Declare variables and cursors */
->
-> /* START Declare Exception Handlers */
->
-> DECLARE CONTINUE HANDLER FOR duplicate_key
-> BEGIN
-> SET p_sqlcode=1052;
-> SET p_status_message='Duplicate key error';
-> END;
->
-> DECLARE CONTINUE HANDLER FOR foreign_key_violated
-> BEGIN
-> SET p_sqlcode=1216;
-> SET p_status_message='Foreign key violated';
-> END;
->
-> DECLARE CONTINUE HANDLER FOR not FOUND
-> BEGIN
-> SET p_sqlcode=1329;
-> SET p_status_message='No record found';
-> END;
->
-> /* END Declare Exception Handlers */
->
-> /* START Execution */
->
-> SET p_sqlcode=0;
-> OPEN csr_mgr_id;
-> FETCH csr_mgr_id INTO l_manager_id;
->
-> IF p_sqlcode<>0 THEN /* Failed to get manager id*/
-> SET p_status_message=CONCAT(p_status_message,' when fetching manager id');
-> ELSE
-> INSERT INTO employee (first_name,id,city)
-> VALUES(p_first_name,l_manager_id,p_city);
->
-> IF p_sqlcode<>0 THEN /* Failed to insert new department */
-> SET p_status_message=CONCAT(p_status_message,
-> ' when inserting new department');
-> END IF;
-> END IF;
->
-> CLOSE csr_mgr_id;
->
-> /* END Execution */
->
-> END$$
Query OK, 0 rows affected (0.02 sec)
mysql>
mysql> delimiter ;
mysql> set @myCode = 0;
Query OK, 0 rows affected (0.00 sec)
mysql> set @myMessage = 0;
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> call myProc('Jason','Martin','New City','New Description',@myCode,@myMessage);
Query OK, 1 row affected (0.00 sec)
mysql>
mysql> select @myCode, @myMessage;
+---------+------------+
| @myCode | @myMessage |
+---------+------------+
| 0 | NULL |
+---------+------------+
1 row in set (0.00 sec)
mysql>
mysql> drop procedure myProc;
Query OK, 0 rows affected (0.00 sec)
希望本文所述對(duì)大家的MySQL數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。
相關(guān)文章
mysql存儲(chǔ)過(guò)程之返回多個(gè)值的方法示例
這篇文章主要介紹了mysql存儲(chǔ)過(guò)程之返回多個(gè)值的方法,結(jié)合實(shí)例形式分析了mysql存儲(chǔ)過(guò)程返回多個(gè)值的實(shí)現(xiàn)方法與PHP調(diào)用技巧,需要的朋友可以參考下2019-12-12
通過(guò)兩種方式增加從庫(kù)——不停止mysql服務(wù)
現(xiàn)在生產(chǎn)環(huán)境MySQL數(shù)據(jù)庫(kù)是一主一從,由于業(yè)務(wù)量訪問(wèn)不斷增大,故再增加一臺(tái)從庫(kù)。前提是不能影響線上業(yè)務(wù)使用,也就是說(shuō)不能重啟MySQL服務(wù),為了避免出現(xiàn)其他情況,選擇在網(wǎng)站訪問(wèn)量低峰期時(shí)間段操作2015-11-11
sql獲取存儲(chǔ)過(guò)程返回?cái)?shù)據(jù)過(guò)程解析
這篇文章主要介紹了sql獲取存儲(chǔ)過(guò)程返回?cái)?shù)據(jù)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
MySQL使用innobackupex備份連接服務(wù)器失敗的解決方法
這篇文章主要為大家詳細(xì)介紹了MySQL使用innobackupex備份連接服務(wù)器失敗的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
查看mysql語(yǔ)句運(yùn)行時(shí)間的2種方法
網(wǎng)站運(yùn)行很慢的時(shí)候,我就特別起知道為什么這么慢,所以我查啊查,數(shù)據(jù)庫(kù)絕對(duì)是很重要的一部分,里面運(yùn)行的sql是絕對(duì)不能放過(guò)的。平時(shí)做項(xiàng)目的時(shí)候,我也會(huì)注意sql語(yǔ)句的書寫,寫出一些高效的sql來(lái),所以我會(huì)經(jīng)常測(cè)試自己寫的sql語(yǔ)句。我把我知道的二個(gè)方法,總結(jié)一下發(fā)出來(lái)2014-01-01
解決MYSQL連接端口被占引入文件路徑錯(cuò)誤的問(wèn)題
下面小編就為大家?guī)?lái)一篇解決MYSQL連接端口被占引入文件路徑錯(cuò)誤的問(wèn)題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08
MySQL中Distinct和Group By語(yǔ)句的基本使用教程
mysql 8.0.12安裝配置方法圖文教程(Windows版)

