MYSQL EXCEPTION HANDLER 範圍與優先順序

來源:互聯網
上載者:User

範圍:

 

1、包括begni..end;內的語句

DECLARE CONTINUE HANDLER FOR 1048 SELECT 'Attempt to insert a null value';
BEGIN
    INSERT INTO a  VALUES (6,NULL);
END;
若a表第二欄位定義為非空,則會觸發1048錯誤 2、若錯誤處理在begin..end內定義,則在之外的語句不會觸發錯誤發生BEGIN
    BEGIN
       DECLARE CONTINUE HANDLER FOR 1216 select
                'Foreign key constraint violated';
    END;
    INSERT INTO departments (department_name,manager_id,location)
         VALUES ('Elbonian HR','Catbert','Catbertia');
END;
3、能夠捕獲其它預存程序拋出的錯誤

 

優先順序:

 

在一個begin...end塊中可以定義多個handler,來分別處理不同的異常。例如:

declare exit handler for sqlexception
    begin
      select 'error';
    end;
      
DECLARE continue HANDLER FOR SQLSTATE '02000' SET done = 1;

 處理的優先順序是:

MySQL Error code > SQLSTATE code > 命名條件 MySQL error code,如1062  
ANSI標準SQLSTATE code,如23000 
命名條件,如NOT FOUND 

 

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.