집 >데이터 베이스 >MySQL 튜토리얼 >업데이트 후 트리거를 사용할 때 '저장된 함수/트리거에서 테이블을 업데이트할 수 없습니다' 오류를 방지하려면 어떻게 해야 합니까?
동일 테이블 업데이트 후 트리거 업데이트
데이터베이스 시스템에서는 테이블 내에서 특정 이벤트가 발생할 때 특정 작업을 자동으로 수행하는 데 트리거가 사용됩니다. 해당 테이블을 업데이트한 후 트리거 내에서 동일한 테이블을 업데이트하려고 할 때 한 가지 일반적인 문제가 발생합니다.
다음 트리거를 고려하세요.
CREATE TRIGGER upd_total_votes AFTER UPDATE ON products_score FOR EACH ROW UPDATE products_score SET products_score.votes_total = (SELECT (votes_1 + votes_2 + votes_3 + votes_4 + votes_5) FROM products_score WHERE id = new.id);
다음과 같이 테이블을 업데이트하려고 할 때 :
UPDATE products_score SET votes_1 = 5 WHERE id = 0;
다음 오류로 인해 트리거가 실패합니다.
#1442 - Can't update table 'products_score' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
이 문제를 해결하려면 트리거는 업데이트 이벤트 이후가 아닌 이전에 실행되도록 수정되어야 합니다. 이렇게 하면 원본 업데이트 문이 적용되기 전에 트리거가 테이블을 업데이트할 수 있습니다.
CREATE TRIGGER upd_total_votes BEFORE UPDATE ON products_score FOR EACH ROW BEGIN SET new.votes_total = new.votes_1 + new.votes_2 + new.votes_3 + new.votes_4 + new.votes_5; END;
이 수정을 통해 테이블을 이전과 같이 업데이트하면 vote_total 열이 성공적으로 업데이트됩니다.
위 내용은 업데이트 후 트리거를 사용할 때 '저장된 함수/트리거에서 테이블을 업데이트할 수 없습니다' 오류를 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!