> 데이터 베이스 > MySQL 튜토리얼 > MySQL 트리거의 'FOR EACH ROW'는 어떻게 작동합니까?

MySQL 트리거의 'FOR EACH ROW'는 어떻게 작동합니까?

PHPz
풀어 주다: 2023-09-06 18:17:06
앞으로
743명이 탐색했습니다.

MySQL 触发器中的“FOR EACH ROW”如何工作?

실제로 "FOR EACH ROW"는 일치하는 모든 행이 업데이트되거나 삭제됨을 의미합니다. 즉, 트리거가 모든 행에 적용되는 것이 아니라 영향을 받는 모든 테이블 행에 대해 트리거 본문이 실행된다는 의미일 뿐입니다. 다음 예를 통해 이를 설명할 수 있습니다. -

이 예에서는 다음과 같이 Sample 및 Sample_rowaffected라는 두 개의 테이블을 생성합니다. -

mysql> Create table Sample(id int, value varchar(20));
Query OK, 0 rows affected (0.47 sec)

mysql> Insert into Sample(id, value) values(100, 'same'),(101,
'Different'),(500, 'excellent'),(501, 'temporary');
Query OK, 4 rows affected (0.04 sec)
Records: 4 Duplicates: 0 Warnings: 0

mysql> Select * from Sample;
+------+-----------+
| id   | value     |
+------+-----------+
| 100  | same      |
| 101  | Different |
| 500  | excellent |
| 501  | temporary |
+------+-----------+
4 rows in set (0.00 sec)

mysql> Create table Sample_rowaffected(id int);
Query OK, 0 rows affected (0.53 sec)

mysql> Select Count(*) as ‘Rows Affected’ from sample_rowaffected;
+---------------+
| Rows Affected |
+---------------+
|             0 |
+---------------+
1 row in set (0.10 sec)
로그인 후 복사

이제 "의 값 이전에 Triggered된 테이블을 삭제하는 트리거를 생성합니다. Sample" -

mysql> Delimiter //
mysql> Create trigger trigger_before_delete_sample BEFORE DELETE on
Sample
    -> FOR EACH ROW
    -> BEGIN
    -> SET @count = if (@count IS NULL, 1, (@count+1));
    -> INSERT INTO sample_rowaffected values (@count);
    -> END ;
    -> //
Query OK, 0 rows affected (0.15 sec)
mysql> Delimiter ;
로그인 후 복사

이제 다음 쿼리는 "Sample" 테이블에서 일부 값을 삭제하고 삭제된 행 수는 @count 사용자 변수에 저장됩니다. -

mysql> Delete from Sample WHERE ID >=500;
Query OK, 2 rows affected (0.11 sec)

mysql> Select @count;
+--------+
| @count |
+--------+
|      2 |
+--------+
1 row in set (0.03 sec)
로그인 후 복사

다음의 도움으로 쿼리를 통해 다음과 같이 Sample_rowaffected 테이블에 삽입된 삭제의 영향을 받은 행의 값을 확인할 수 있습니다. -

mysql> Select Count(*) as 'Rows Affected' from sample_rowaffected;
+---------------+
| Rows Affected |
+---------------+
|             2 |
+---------------+
1 row in set (0.00 sec)

mysql> Select * from Sample;
+------+-----------+
| id   | value     |
+------+-----------+
| 100  | same      |
| 101  | Different |
+------+-----------+
2 rows in set (0.00 sec)
로그인 후 복사

위 예의 도움으로 "FOR EACH ROW"는 일치하는 모든 행을 의미한다는 것이 분명해졌습니다. 업데이트 또는 삭제되었습니다.

위 내용은 MySQL 트리거의 'FOR EACH ROW'는 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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