>데이터 베이스 >MySQL 튜토리얼 >저장된 함수 및 트리거에서 MySQL 블록 테이블 수정이 수행되는 이유는 무엇입니까?

저장된 함수 및 트리거에서 MySQL 블록 테이블 수정이 수행되는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-07 13:16:18283검색

Why Does MySQL Block Table Modification in Stored Functions and Triggers?

MySQL 저장 함수/트리거 오류: 테이블 수정이 차단됨

MySQL에서 저장 함수나 트리거를 실행할 때 다음 오류가 발생할 수 있습니다.

Error: Can't update table 'brandnames' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.

이 오류는 저장된 함수 또는 트리거 내에서 테이블을 업데이트하려고 할 때 발생하며, 이는 잠재적 교착 상태 또는 무한 재귀로 인해 금지됩니다.

제공된 것과 같은 INSERT 트리거:

CREATE TRIGGER `capital` AFTER INSERT ON `brandnames`
FOR EACH ROW UPDATE brandnames
SET bname = CONCAT( UCASE( LEFT( bname, 1 ) ) , LCASE( SUBSTRING( bname, 2 ) ) )

INSERT 작업이 계속 활성 상태인 동안 브랜드 이름 테이블을 업데이트하려고 시도합니다. MySQL은 이를 방지하여 데이터 무결성을 유지하고 잠재적인 오류를 방지합니다.

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

  • 새 값에 액세스: NEW 사용 .fieldname INSERT 작업 중에 설정된 값에 액세스합니다. 이를 통해 테이블에 영향을 주지 않고 파생된 값을 수정할 수 있습니다.
  • Before 트리거 사용: 가능하면 테이블 수정 로직을 BEFORE INSERT 트리거로 이동하세요. 이를 통해 INSERT가 완료되기 전에 파생된 값을 설정하여 오류를 방지할 수 있습니다.

예를 들어 다음 트리거는 full_name 열의 값을 기반으로 small_name 열을 업데이트합니다.

CREATE TRIGGER `capital` BEFORE INSERT ON `brandnames`
FOR EACH ROW BEGIN
  SET NEW.small_name = CONCAT(UCASE(LEFT(NEW.full_name,1)) , LCASE(SUBSTRING(NEW.full_name,2)))
END

위 내용은 저장된 함수 및 트리거에서 MySQL 블록 테이블 수정이 수행되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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