MySQL의 트리거 및 테이블 업데이트
트리거를 사용하여 INSERT 작업 후 동일한 테이블을 업데이트하려고 하면 사용자에게 오류가 발생할 수 있습니다. "ACCOUNTS 테이블을 업데이트할 수 없습니다. 이 트리거를 호출한 문에서 이미 사용되었습니다." 이 제한은 현재 트리거 문에서 사용 중인 테이블 수정에 대한 제한으로 인해 발생합니다.
이 문제를 해결하기 위해 트리거에만 의존하는 것은 불가능합니다. 대신 단일 트랜잭션 내에서 INSERT 및 업데이트 작업을 모두 처리하기 위한 저장 프로시저를 만들어야 합니다. 저장 프로시저를 사용하여 변경 사항을 수동으로 커밋하면 사용자는 트리거로 인한 제약 조건을 피할 수 있습니다.
저장 프로시저 해결 방법 구현 단계:
CREATE PROCEDURE update_accounts_status(IN new_account_pk BIGINT) AS BEGIN -- Insert new account INSERT INTO ACCOUNTS (user_id, edit_on, status) VALUES (?, ?, 'A'); -- Update old account UPDATE ACCOUNTS SET status = 'E' WHERE pk = ?; -- Commit changes COMMIT; END
트리거를 사용하는 대신 저장 프로시저에서 다음을 수행할 수 있습니다. ACCOUNTS 테이블에 INSERT 시 호출됩니다. 이렇게 하면 삽입 및 업데이트 작업이 모두 단일 트랜잭션 내에서 성공적으로 실행되고 커밋됩니다.
저장 프로시저 사용의 장점:
위 내용은 INSERT 트리거 후 오류 없이 MySQL 테이블을 업데이트하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!