> 데이터 베이스 > MySQL 튜토리얼 > SQL 트리거 적용

SQL 트리거 적용

王林
풀어 주다: 2024-02-19 16:09:06
원래의
833명이 탐색했습니다.

SQL 트리거 적용

SQL 트리거의 역할 및 특정 코드 예

개요: SQL 트리거는 데이터베이스의 데이터가 변경될 때 자동으로 실행되는 코드 조각인 특수 저장 프로시저입니다. 트리거는 데이터가 삽입(INSERT), 업데이트(UPDATE) 또는 삭제(DELETE)될 때 실행을 트리거할 수 있습니다. 이는 다양하고 복잡한 데이터 제약 조건, 비즈니스 로직 및 데이터 일관성 제어를 구현하는 데 사용될 수 있습니다.

기능:

  1. 데이터 무결성 제어: 트리거를 통해 데이터베이스에 몇 가지 규칙을 정의하여 데이터의 무결성과 일관성을 보장할 수 있습니다. 예를 들어 트리거를 사용하여 필드의 값 범위를 제한하고 관련 테이블의 외래 키 제약 조건을 확인할 수 있습니다.
  2. 비즈니스 로직 제어: 트리거는 데이터베이스 수준에서 비즈니스 로직 제어를 구현하는 데 도움이 될 수 있습니다. 예를 들어 주문 테이블에 레코드가 삽입되면 트리거를 통해 주문 총액이 자동으로 계산되어 해당 필드에 업데이트될 수 있습니다.
  3. 데이터 동기화 및 복제: 여러 데이터베이스 간의 데이터 동기화 및 복제를 구현할 때 소스 데이터베이스에서 데이터 변경이 발생할 때 트리거를 사용하여 대상 데이터베이스에 대한 업데이트를 동기화할 수 있습니다.
  4. 로깅 및 감사: 트리거를 통해 데이터베이스 작업에 대한 로깅 및 감사 기능을 구현할 수 있습니다. 즉, 데이터가 변경되면 트리거가 관련 작업을 자동으로 기록하여 후속 쿼리 및 추적을 용이하게 할 수 있습니다.

코드 예:
다음은 새 레코드가 삽입될 때 다른 요약 테이블의 데이터를 자동으로 업데이트하는 MySQL에서 트리거를 생성하는 방법을 보여주는 간단한 예입니다.

  1. 두 개의 테이블 생성:
CREATE TABLE orders (
  id INT PRIMARY KEY,
  amount DECIMAL(8,2),
  status ENUM('pending', 'complete')
);

CREATE TABLE summary (
  total_amount DECIMAL(8,2)
);
로그인 후 복사
  1. 새 레코드가 주문 테이블에 삽입될 때 요약 테이블의 total_amount 필드를 자동으로 업데이트하는 트리거 생성:
DELIMITER $$
CREATE TRIGGER update_summary AFTER INSERT ON orders
FOR EACH ROW
BEGIN
  UPDATE summary SET total_amount = total_amount + NEW.amount;
END$$
DELIMITER ;
로그인 후 복사
  1. 트리거를 트리거하는 새 레코드 삽입 실행 :
INSERT INTO orders (id, amount, status) VALUES (1, 100.00, 'complete');
로그인 후 복사
  1. 요약 테이블을 쿼리하고 트리거의 효과를 확인합니다.
SELECT * FROM summary;
로그인 후 복사

위의 코드 예제를 통해 새 레코드가 주문 테이블에 삽입되면 트리거가 자동으로 요약을 업데이트하는 것을 볼 수 있습니다. table. 을 통해 total_amount 필드를 실시간으로 업데이트합니다.

요약:
SQL 트리거는 데이터가 변경될 때 자동으로 코드를 실행할 수 있는 강력한 도구입니다. 트리거를 통해 데이터 무결성 제어, 비즈니스 로직 제어, 데이터 동기화 및 복제, 로깅 및 감사와 같은 기능을 구현할 수 있습니다. 실제 애플리케이션 개발 시, 트리거를 합리적으로 사용하면 데이터베이스의 보안성과 신뢰성을 향상시킬 수 있습니다.

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

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