트리거로 인해 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에서 보편적으로 지원되지 않습니다. 그러나 일부 데이터베이스는 트리거 내의 유효성 검사 오류를 처리하기 위한 대체 메커니즘을 제공합니다. 예:
위 내용은 MySQL 트리거가 INSERT 작업 실패를 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!