>데이터 베이스 >SQL >SQL 트리거의 사용 및 구문

SQL 트리거의 사용 및 구문

小老鼠
小老鼠원래의
2024-04-13 14:57:161136검색

트리거는 특정 이벤트(삽입, 업데이트, 삭제)가 발생할 때 자동으로 실행되는 데이터베이스 코드입니다. 트리거 구문에는 트리거 이름, 테이블 이름, 트리거 시간(BEFORE/AFTER) 및 이벤트 유형(INSERT/UPDATE/DELETE)이 포함됩니다. 트리거 유형에는 BEFORE, AFTER가 있고 이벤트 유형에는 INSERT, UPDATE, DELETE가 있습니다. 트리거는 데이터 무결성 확인, 감사 로깅, 자동화된 작업 및 비즈니스 논리에 사용될 수 있습니다. 예를 들어 데이터 일관성을 보장하기 위해 새 행이 삽입될 때 삽입 시간을 기록하는 트리거를 만들 수 있습니다.

SQL 트리거의 사용 및 구문

SQL 트리거 사용법 및 구문

트리거란 무엇인가요?

트리거는 데이터베이스에서 특정 이벤트가 발생할 때 자동으로 실행을 트리거하는 데이터베이스의 코드 조각입니다. 데이터가 변경될 때 사용자 지정 작업을 수행하는 데 사용됩니다.

트리거 구문

SQL의 트리거 구문은 다음과 같습니다.

<code>CREATE TRIGGER trigger_name
ON table_name
FOR INSERT | UPDATE | DELETE
AS
BEGIN
   -- 触发器代码...
END;</code>

트리거 유형

트리거는 트리거링 타이밍에 따라 다음과 같은 유형으로 나눌 수 있습니다.

  • BEFORE code> 트리거: 이벤트가 발생하기 전에 실행됩니다.
  • BEFORE 触发器:在事件发生之前执行。
  • AFTER 触发器:在事件发生之后执行。

根据事件类型,触发器可分为:

  • INSERT 触发器:在插入新行时触发。
  • UPDATE 触发器:在更新现有行时触发。
  • DELETE 触发器:在删除行时触发。

触发器的使用场景

触发器广泛用于以下场景:

  • 数据完整性验证:确保数据符合特定规则(例如,非空约束、唯一性约束)。
  • 审计和记录:跟踪数据库中的变化并记录用户活动。
  • 自动任务:在数据更改时自动执行特定任务(例如,发送电子邮件通知)。
  • 业务逻辑:实现复杂的业务规则,例如计算 derived column 或维护关联表。

示例

以下是一个示例触发器,用于在向 users 表中插入新行时记录插入时间:

<code class="sql">CREATE TRIGGER insert_timestamp
BEFORE INSERT ON users
AS
BEGIN
   SET NEW.created_at = CURRENT_TIMESTAMP();
END;</code>

当插入新行到 users 表时,insert_timestamp 触发器会在插入之前执行,并自动将当前时间戳设置为新建行的 created_atAFTER 트리거: 이벤트가 발생한 후에 실행됩니다.

이벤트 유형에 따라 트리거는 다음과 같이 나눌 수 있습니다. 🎜🎜🎜INSERT 트리거: 새 행이 삽입될 때 트리거됩니다. 🎜UPDATE 트리거: 기존 행이 업데이트될 때 실행됩니다. 🎜DELETE 트리거: 행이 삭제되면 실행됩니다. 🎜🎜트리거 사용 시나리오🎜🎜🎜트리거는 다음 시나리오에서 널리 사용됩니다. 🎜🎜🎜🎜데이터 무결성 확인: 🎜데이터가 특정 규칙(예: null이 아닌 제약 조건)을 준수하는지 확인 , 고유성 제약 조건). 🎜🎜감사 및 로깅: 🎜데이터베이스의 변경 사항을 추적하고 사용자 활동을 기록합니다. 🎜🎜자동 작업: 🎜데이터가 변경되면 특정 작업을 자동으로 수행합니다(예: 이메일 알림 보내기). 🎜🎜비즈니스 논리: 🎜파생 열 계산, 관련 테이블 유지 관리 등 복잡한 비즈니스 규칙을 구현합니다. 🎜🎜Example🎜🎜🎜다음은 users 테이블에 새 행이 삽입될 때 삽입 시간을 기록하는 예제 트리거입니다. 🎜rrreee🎜새 행이 삽입됨 users 테이블로 이동하면 삽입하기 전에 insert_timestamp 트리거가 실행되어 현재 타임스탬프를 새 행의 created_at 필드로 자동 설정합니다. . 🎜

위 내용은 SQL 트리거의 사용 및 구문의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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