> 데이터 베이스 > MySQL 튜토리얼 > INSERT 트리거 후 오류 없이 MySQL 테이블을 업데이트하려면 어떻게 해야 합니까?

INSERT 트리거 후 오류 없이 MySQL 테이블을 업데이트하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-12-27 00:54:17
원래의
632명이 탐색했습니다.

How Can I Update a MySQL Table After an INSERT Trigger Without Errors?

MySQL의 트리거 및 테이블 업데이트

트리거를 사용하여 INSERT 작업 후 동일한 테이블을 업데이트하려고 하면 사용자에게 오류가 발생할 수 있습니다. "ACCOUNTS 테이블을 업데이트할 수 없습니다. 이 트리거를 호출한 문에서 이미 사용되었습니다." 이 제한은 현재 트리거 문에서 사용 중인 테이블 수정에 대한 제한으로 인해 발생합니다.

이 문제를 해결하기 위해 트리거에만 의존하는 것은 불가능합니다. 대신 단일 트랜잭션 내에서 INSERT 및 업데이트 작업을 모두 처리하기 위한 저장 프로시저를 만들어야 합니다. 저장 프로시저를 사용하여 변경 사항을 수동으로 커밋하면 사용자는 트리거로 인한 제약 조건을 피할 수 있습니다.

저장 프로시저 해결 방법 구현 단계:

  1. 저장소 만들기 프로시저:
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
로그인 후 복사
  1. 저장 프로시저 호출:

트리거를 사용하는 대신 저장 프로시저에서 다음을 수행할 수 있습니다. ACCOUNTS 테이블에 INSERT 시 호출됩니다. 이렇게 하면 삽입 및 업데이트 작업이 모두 단일 트랜잭션 내에서 성공적으로 실행되고 커밋됩니다.

저장 프로시저 사용의 장점:

  • 제한을 피합니다. 트리거 내에서 동일한 테이블을 업데이트합니다.
  • transaction.
  • 단일 트랜잭션 내에서 여러 작업(예: 삽입 및 업데이트)을 쉽게 실행할 수 있습니다.

위 내용은 INSERT 트리거 후 오류 없이 MySQL 테이블을 업데이트하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿