>  기사  >  데이터 베이스  >  MySQL 트리거가 INSERT 작업 실패를 방지할 수 있습니까?

MySQL 트리거가 INSERT 작업 실패를 방지할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-14 09:56:02514검색

Can MySQL Triggers Prevent INSERT Operations from Failing?

트리거로 인해 INSERT 실패 발생

MySQL의 트리거는 삽입이나 업데이트 전에 데이터를 수정할 수 있지만 처음에는 그럴 수 있다고 믿었습니다. 작업 실패를 방지하지 마십시오. 그러나 더 자세히 조사한 결과 이 ​​기능을 달성할 수 있는 방법이 있음이 밝혀졌습니다.

MySQL의 해결 방법

MySQL 버전 5.0 및 5.1에서는 작업을 중단하는 해결 방법을 사용할 수 있습니다. 오류 메시지를 트리거하고 제공합니다. 여기에는 존재하지 않는 열에 대한 액세스 시도가 포함됩니다.

CREATE TRIGGER mytabletriggerexample
BEFORE INSERT
FOR EACH ROW
BEGIN
IF(NEW.important_value) < (fancy * dancy * calculation) THEN
    DECLARE dummy INT;

    SELECT Your meaningful error message goes here INTO dummy 
        FROM mytable
      WHERE mytable.id=new.id
END IF; END;

조건이 충족되면 트리거가 존재하지 않는 테이블에서 오류 메시지를 선택하려고 시도하여 제공된 메시지와 함께 삽입이 실패하게 됩니다. .

기타 RDBMS

트리거 내에서 예외를 발생시키고 작업을 중단하는 기능은 모든 RDBMS에서 보편적으로 지원되지 않습니다. 그러나 일부 데이터베이스는 트리거 내의 유효성 검사 오류를 처리하기 위한 대체 메커니즘을 제공합니다. 예:

  • PostgreSQL: RAISE EXCEPTION 명령을 사용하여 예외를 발생시키고 오류 메시지를 제공할 수 있습니다.
  • Oracle: SIGNAL 문을 사용하면 트리거 내에서 경고 또는 오류를 발생시킬 수 있습니다.

위 내용은 MySQL 트리거가 INSERT 작업 실패를 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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