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은 두 가지 주요 이유로 이 동작을 금지합니다.
이 오류를 해결하려면 다음 방법을 사용하는 것이 좋습니다.
예를 들어 전체 이름의 처음 두 문자로 짧은 이름 필드를 생성하려면 다음 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!