>데이터 베이스 >MySQL 튜토리얼 >업데이트 후 트리거를 사용할 때 '저장된 함수/트리거에서 테이블을 업데이트할 수 없습니다' 오류를 방지하려면 어떻게 해야 합니까?

업데이트 후 트리거를 사용할 때 '저장된 함수/트리거에서 테이블을 업데이트할 수 없습니다' 오류를 방지하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-26 22:28:14711검색

How Can I Prevent

동일 테이블 업데이트 후 트리거 업데이트

데이터베이스 시스템에서는 테이블 내에서 특정 이벤트가 발생할 때 특정 작업을 자동으로 수행하는 데 트리거가 사용됩니다. 해당 테이블을 업데이트한 후 트리거 내에서 동일한 테이블을 업데이트하려고 할 때 한 가지 일반적인 문제가 발생합니다.

다음 트리거를 고려하세요.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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