SELECT 문으로 MySQL 트리거를 실행할 수 있나요?

Mary-Kate Olsen
풀어 주다: 2024-11-03 21:59:30
원래의
482명이 탐색했습니다.

Can MySQL Triggers Be Fired by SELECT Statements?

MySQL이 SELECT 문에서 실행할 수 있습니까?

SELECT 문이 테이블 X에서 데이터를 검색할 때마다 테이블 X에서 INSERT 작업을 트리거하려고 합니다. 표 Y. 이로 인해 MySQL이 트리거만을 사용하여 이 목표를 달성하기 위한 메커니즘을 제공하는지 여부에 대한 의문이 제기됩니다.

MySQL 트리거의 제한 사항

안타깝게도 MySQL 트리거는 다음과 같이 설계되었습니다. INSERT, UPDATE 또는 DELETE 작업에 구체적으로 응답합니다. SELECT 문으로 기능을 확장하지 않습니다.

희귀한 시나리오에 대한 대체 솔루션

MySQL 트리거는 이 시나리오에 적합하지 않을 수 있지만 다음과 같은 해결 방법이 있습니다. 저장 프로시저 사용:

  1. SELECT 쿼리에 대한 저장 프로시저 생성:

    • 원하는 SELECT 작업을 수행하는 저장 프로시저 생성 테이블 X.
  2. 직접 SELECT 액세스 제한:

    • 테이블 X에서 직접 SELECT 문을 방지하도록 사용자 권한을 수정합니다. 사용자가 귀하가 생성한 저장 프로시저를 통해서만 데이터에 액세스할 수 있는지 확인하세요.
  3. 저장 프로시저에 INSERT 작업 통합:

    • SELECT 결과에 따라 INSERT 작업이나 기타 원하는 작업을 실행하는 다른 저장 프로시저에 대한 호출을 포함하도록 저장 프로시저를 변경합니다.

위 내용은 SELECT 문으로 MySQL 트리거를 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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