mysql存儲過程怎樣抓取報錯信息?
問題描述
執行mysql存儲過程;怎樣像o/m數據庫抓取出報錯信息輸出到log表呢?mssql可以直接引用ERROR_MESSAGE()
查資料只能到查到有錯誤時賦值變量,應該至少可以抓到個error code啊
DECLARE t_error INT DEFAULT 0; DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error = 1;
大家看看怎么實現
問題解答
回答1:declare exit handler for sqlexception
BEGIN rollback;#或者看自己需求 GET DIAGNOSTICS CONDITION 1 # dev.mysql.com/doc/refman/5.7/en/get-diagnostics.html@p2 = MESSAGE_TEXT; insert into tbl_log_info (SINFO,STYPE,STEMP,srun_info) values(’proc_’,’proc_’,’action’,@p2); commit;END;
/開始事物/ start transaction;
回答2:弄了一下午終于搞定;不得不說mysql的流程控制好差勁!錯誤發生時經常抓取不到error,code直接賦值null,這樣判斷事物提交時被坑了一把;文檔里的抓取數據影響行數的功能沒測通,輸出結果始終是0,可能用法也不對吧,沒找到正確姿勢.
另外推薦個mysql存儲過程調試工具 dbForge Studio for MySQL使用時記得只在測試庫上debug,因為它會給存儲過程加代碼,在數據庫中新建存儲調試信息的庫.
相關文章:
1. javascript - 回調函數和閉包的關系2. javascript - 在top.jsp點擊退出按鈕后,right.jsp進行頁面跳轉,跳轉到login.jsp3. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點4. mac連接阿里云docker集群,已經卡了2天了,求問?5. javascript - 下面的這段算法代碼求解釋6. css3 - 在sublime text里, 如何讓emmet生成的帶前綴css屬性垂直對齊?7. javascript - js 有什么優雅的辦法實現在同時打開的兩個標簽頁間相互通信?8. java - spring-data Jpa 不需要執行save 語句,Set字段就可以自動執行保存的方法?求解9. [前端求職必看]前端開發面試題與答案精選_擴展問題10. 想找個php大神仿個網站。
