데이터 베이스 MySQL 튜토리얼 MySQL 5.5新增SIGNAL异常处理_MySQL

MySQL 5.5新增SIGNAL异常处理_MySQL

Jun 01, 2016 pm 01:41 PM
이상

bitsCN.com
MySQL 5.5新增SIGNAL异常处理 MySQL 从 5.0 开始支持存储过程,到现在最新版本5.5 已经好几个年头了。 虽然MYSQL的异常处理不是很完善,但是处理大多数的应用还是足够了。   异常处理的语句有如下几种:1. DECLARE ... CONDITION.2. DECLARE ... HANDLER.3. RESIGNAL.4. SIGNAL. 第一种,名为条件声明。DECLARE condition_name CONDITION FOR condition_value 这里condition_name 为标准的变量命名, condition_value 为SQLSTATE 值 或者 MySQL 自身的ERROR CODE.单独的condition 语句不能直接运行。 只能作为第二种的一部分。   第二种, 名为条件处理。第一种声明好了,接下来自然要做相应的处理。DECLARE handler_action HANDLER    FOR condition_value [, condition_value] ...    statement handler_action:    CONTINUE  | EXIT  | UNDO condition_value:    mysql_error_code  | SQLSTATE [VALUE] sqlstate_value  | condition_name  | SQLWARNING  | NOT FOUND  | SQLEXCEPTION handler_action 代表处理的动作,目前有效的有两种, 继续和直接退出。condition_value 有好几种,其中包括前面条件声明里的SQLSTATE, MYSQL EEROR CODE, condition_name 以及范围混淆的其他两种SQLWARNING,SQLEXCEPTION. NOT FOUND表示任何不存在的WARNING或者ERROR。 第三种, 代表伪装系统的错误信息以及代码,刷新当前警告缓冲区域。RESIGNAL [condition_value]    [SET signal_information_item    [, signal_information_item] ...] condition_value:    SQLSTATE [VALUE] sqlstate_value  | condition_name signal_information_item:    condition_information_item_name = simple_value_specification condition_information_item_name:    CLASS_ORIGIN  | SUBCLASS_ORIGIN  | MESSAGE_TEXT  | MYSQL_ERRNO  | CONSTRAINT_CATALOG  | CONSTRAINT_SCHEMA  | CONSTRAINT_NAME  | CATALOG_NAME  | SCHEMA_NAME  | TABLE_NAME  | COLUMN_NAME  | CURSOR_NAME 特别注意的是可以伪装的具体东西很多,包括错误代码(MYSQL自身的东东),错误内容,错误的数据库名,表名,列名等等。 第四种,SIGNAL和RESIGNAL差别不大,我们记住signal 不能单独运行,resignal可以单独运行。SIGNAL condition_value    [SET signal_information_item    [, signal_information_item] ...] condition_value:    SQLSTATE [VALUE] sqlstate_value  | condition_name signal_information_item:    condition_information_item_name = simple_value_specification condition_information_item_name:    CLASS_ORIGIN  | SUBCLASS_ORIGIN  | MESSAGE_TEXT  | MYSQL_ERRNO  | CONSTRAINT_CATALOG  | CONSTRAINT_SCHEMA  | CONSTRAINT_NAME  | CATALOG_NAME  | SCHEMA_NAME  | TABLE_NAME  | COLUMN_NAME  | CURSOR_NAME 我们现在给几个例子。 不用RESIGNAL/SIGNAL。[sql] DELIMITER $$    USE `t_girl`$$    DROP PROCEDURE IF EXISTS `sp_signal1`$$    CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_signal1`(      IN f_id INT      )  BEGIN        DECLARE con1 TINYINT DEFAULT 0;        DECLARE con1 CONDITION FOR SQLSTATE '23000';        DECLARE CONTINUE HANDLER FOR con1        BEGIN          SELECT 'Error Code : 22/r/nDuplicated!';        END;        INSERT INTO user_info VALUES (f_id);      END$$    DELIMITER ;   CALL sp_signal1(12); query result resultError Code : 22Duplicated! 用RESIGNAL/SIGNAL 重刷当前错误诊断区域。 [sql] DELIMITER $$         USE `t_girl`$$      DROP PROCEDURE IF EXISTS `sp_signal1`$$      CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_signal1`(      IN f_id INT      )  BEGIN        DECLARE con1 TINYINT DEFAULT 0;        DECLARE con1 CONDITION FOR SQLSTATE '23000';        DECLARE CONTINUE HANDLER FOR con1        BEGIN          resignal SET schema_name = 'action',                table_name = 'action_tb',                message_text = 'Duplicated!',                       mysql_errno = 22;  /*             signal con1 SET schema_name = 'action',                table_name = 'action_tb',                message_text = 'Duplicated!',                       mysql_errno = 22;         */        END;        INSERT INTO user_info VALUES (f_id);      END$$    DELIMITER ;   CALL sp_signal1(12);   Query : call sp_signal1(12)Error Code : 22Duplicated!Execution Time : 00:00:00:000Transfer Time  : 00:00:00:000Total Time     : 00:00:00:000  作者 四爷 bitsCN.com

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Java에서 OutOfMemoryError 예외의 일반적인 원인은 무엇입니까? Java에서 OutOfMemoryError 예외의 일반적인 원인은 무엇입니까? Jun 25, 2023 pm 08:43 PM

Java는 가장 널리 사용되는 프로그래밍 언어 중 하나이지만 Java를 사용하여 애플리케이션을 개발할 때 "OutOfMemoryError" 예외 오류가 발생하기 쉬우며, 이는 개발자에게 종종 어려움을 안겨줍니다. Java에서 OutOfMemoryError 예외가 발생하는 정확한 원인은 무엇입니까? 다음으로 이에 대해 자세히 알아보겠습니다. 메모리 누수(MemoryLeak) 메모리 누수는 가비지 수집기에서 객체를 재활용할 수 없는 경우를 의미하며 이로 인해 메모리 누수가 발생합니다.

Java 반사 예외(ReflectiveOperationException)를 해결하는 방법 Java 반사 예외(ReflectiveOperationException)를 해결하는 방법 Aug 26, 2023 am 09:55 AM

Java 리플렉션 예외(ReflectiveOperationException)를 해결하는 방법 Java 개발에서 리플렉션(Reflection)은 프로그램이 런타임 시 클래스, 개체, 메서드, 속성 등을 동적으로 획득하고 작동할 수 있도록 하는 강력한 메커니즘입니다. 리플렉션을 통해 동적으로 객체 생성, 프라이빗 메서드 호출, 클래스 주석 획득 등과 같은 유연한 기능을 구현할 수 있습니다. 그러나 리플렉션을 사용하면 잠재적인 위험과 문제가 발생할 수도 있으며, 그 중 하나는 리플렉션 이상입니다(

Java 스레드 인터럽트 시간 초과 예외를 해결하는 방법(ThreadInterruptedTimeoutExceotion) Java 스레드 인터럽트 시간 초과 예외를 해결하는 방법(ThreadInterruptedTimeoutExceotion) Aug 18, 2023 pm 01:57 PM

Java 스레드 인터럽트 시간 초과 예외(ThreadInterruptedTimeoutException)를 해결하는 방법 Java 다중 스레드 프로그래밍에서는 스레드 실행 시간이 너무 긴 상황이 자주 발생합니다. 스레드가 너무 많은 시스템 자원을 점유하는 것을 방지하기 위해 우리는 일반적으로 타임아웃을 설정합니다. 스레드 실행 시간이 타임아웃을 초과하면 스레드 실행을 중단할 수 있기를 바랍니다. Java는 스레드의 Interrupt() 메소드를 호출하여 스레드 중단 메커니즘을 제공합니다.

MIT의 최신 걸작: GPT-3.5를 사용하여 시계열 이상 탐지 문제 해결 MIT의 최신 걸작: GPT-3.5를 사용하여 시계열 이상 탐지 문제 해결 Jun 08, 2024 pm 06:09 PM

오늘은 지난 주 MIT에서 발표한 기사를 소개하고자 합니다. GPT-3.5-turbo를 사용하여 시계열 이상 탐지 문제를 해결하고, 시계열 이상 탐지에서 LLM의 효율성을 초기에 검증한 내용입니다. 전체 과정에 미세한 조정은 없으며, 이상 탐지를 위해 GPT-3.5-turbo를 직접 사용하는 것이 이 글의 핵심이다. LLM이 이상 탐지 작업을 해결하도록 하는 프롬프트 또는 파이프라인입니다. 이 작품을 자세히 소개하겠습니다. 이미지 논문 제목: Large Languagemodelscanbezero-shotanomalydete

로닌 라이즈 풀의 특이한 미션 가이드 로닌 라이즈 풀의 특이한 미션 가이드 Mar 26, 2024 pm 08:06 PM

수영장의 이상 현상은 게임의 부수적인 작업입니다. 많은 플레이어들이 수영장 작업의 이상 현상을 완료하는 방법을 알고 싶어합니다. 먼저, 물 속에서의 사격 기술을 익혀야 합니다. 나중에 우리는 수영장 아래에 많은 시체가 있다는 것을 발견했습니다. Rise of Ronin의 수영장에서 특이한 작업에 대한 이 그래픽 가이드를 살펴보겠습니다. Ronin Rise Pool의 특이한 임무 안내: 1. Iizuka와 대화하고 물 속에서 사격하는 기술을 배웁니다. 2. 풀에서 비정상적인 태스크를 받으려면 아래 그림의 위치로 이동하세요. 3. 미션 장소로 이동하여 NPC에게 말을 걸면, 근처 수영장에서 악취가 난다는 것을 알게 됩니다. 4. 조사를 위해 수영장으로 이동합니다. 5. 아래 사진의 위치로 수영하여 수중 다이빙을 하면 시체를 많이 발견하게 됩니다. 6. 카메라를 이용해 시체 사진을 찍어보세요. 7

Java 네트워크 연결 재설정 예외(ConnectionResetException)를 해결하는 방법 Java 네트워크 연결 재설정 예외(ConnectionResetException)를 해결하는 방법 Aug 26, 2023 pm 07:57 PM

Java 네트워크 연결 재설정 예외(ConnectionResetException) 해결 방법 Java 네트워크 프로그래밍을 수행할 때 네트워크 연결 재설정 예외(ConnectionResetException)가 자주 발생합니다. 이 예외는 연결이 설정된 후 다른 호스트가 실수로 연결을 닫았음을 의미합니다. 이는 상대방 호스트의 충돌, 네트워크 중단 또는 방화벽 구성으로 인해 발생할 수 있습니다. 네트워크 애플리케이션을 작성할 때 프로그램이 정상적으로 실행될 수 있도록 이 예외를 처리해야 합니다.

사운드카드 드라이버 이상 해결 방법 사운드카드 드라이버 이상 해결 방법 Feb 22, 2024 am 09:10 AM

일부 사용자는 컴퓨터를 사용할 때 갑자기 사운드 카드 드라이버가 비정상임을 발견합니다. 이 경우 장치 관리자에서 드라이버를 업데이트하거나 드라이버를 롤백하여 문제가 성공적으로 해결되었는지 확인할 수 있습니다. 사운드 카드 드라이버 이상 해결 방법 1. "이 PC"를 마우스 오른쪽 버튼으로 클릭하고 "관리"를 선택합니다. 2. "장치 관리자"를 클릭하고 "사운드"를 클릭합니다. 3. 드라이버를 마우스 오른쪽 버튼으로 클릭하고 "속성"을 선택합니다. 4. "드라이버"를 클릭합니다. "를 클릭한 후 아래를 클릭하세요. "업데이트 또는 롤백"을 선택할 수 있습니다.

C++ 함수 예외 및 단일 테스트: 코드 건전성 보장 C++ 함수 예외 및 단일 테스트: 코드 건전성 보장 May 03, 2024 am 09:18 AM

예외 처리 및 단위 테스트는 C++ 코드의 건전성을 보장하는 중요한 방법입니다. 예외는 try-catch 블록을 통해 처리되며, 코드에서 예외가 발생하면 catch 블록으로 이동합니다. 단위 테스트는 코드 테스트를 분리하여 예외 처리가 다양한 상황에서 예상대로 작동하는지 확인합니다. 실제 사례: sumArray 함수는 배열 요소의 합계를 계산하고 빈 입력 배열을 처리하기 위해 예외를 발생시킵니다. 단위 테스트는 배열이 비어 있을 때 std::invalid_argument 예외를 발생시키는 등 비정상적인 상황에서 예상되는 함수 동작을 확인합니다. 결론: 예외 처리 및 단위 테스트를 활용하여 예외를 처리하고, 코드 충돌을 방지하고, 비정상적인 조건에서 코드가 예상대로 작동하는지 확인할 수 있습니다.

See all articles