> 데이터 베이스 > MySQL 튜토리얼 > MySQL 저장 함수 또는 트리거 내의 테이블을 업데이트할 수 없는 이유는 무엇입니까?

MySQL 저장 함수 또는 트리거 내의 테이블을 업데이트할 수 없는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-25 00:05:20
원래의
818명이 탐색했습니다.

Why Can't I Update a Table Within a MySQL Stored Function or Trigger?

MySQL 오류: 저장된 함수/트리거에서 테이블을 업데이트할 수 없습니다

질문:

트리거를 사용하여 MySQL 테이블에 새 행을 삽입하려고 하면 다음 오류가 발생합니다. 발생:

Can't update table 'brandnames' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
로그인 후 복사

답변:

이 오류는 INSERT 트리거가 이를 호출한 테이블을 수정하려고 시도할 때 발생합니다. MySQL은 두 가지 주요 이유로 이 동작을 금지합니다.

  • 잠금 충돌: INSERT는 잠금 작업을 수행할 수 있으며, 이는 트리거가 테이블 잠금을 시도하는 경우 교착 상태로 이어질 수 있습니다.
  • 무한 재귀: 트리거가 동일한 테이블의 행을 업데이트하는 경우 동일한 트리거가 무기한 실행되어 무한 루프가 발생합니다.

이 오류를 해결하려면 다음 방법을 사용하는 것이 좋습니다.

  • 새 값에 액세스 : 트리거에서 테이블을 수정하는 대신 NEW.fieldname을 사용하여 새로 삽입된 값에 액세스하고 다른 필드를 설정하세요.
  • 삽입 전 수정: 값이 테이블에 삽입되기 전에 BEFORE INSERT 트리거를 사용하여 값을 수정합니다. 이렇게 하면 무한 재귀 문제를 방지할 수 있습니다.

예를 들어 전체 이름의 처음 두 문자로 짧은 이름 필드를 생성하려면 다음 BEFORE INSERT 트리거를 사용할 수 있습니다.

CREATE TRIGGER `capital` BEFORE INSERT ON `brandnames`
FOR EACH ROW BEGIN
  SET NEW.short_name = CONCAT(UCASE(LEFT(NEW.full_name,1)) , LCASE(SUBSTRING(NEW.full_name,2)))
END
로그인 후 복사

위 내용은 MySQL 저장 함수 또는 트리거 내의 테이블을 업데이트할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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