> 데이터 베이스 > MySQL 튜토리얼 > MySQL 상위 테이블에서 행을 삭제하면 어떻게 되나요?

MySQL 상위 테이블에서 행을 삭제하면 어떻게 되나요?

WBOY
풀어 주다: 2023-09-03 21:17:02
앞으로
664명이 탐색했습니다.

如果我从 MySQL 父表中删除一行会发生什么?

상위 테이블에서 행이 삭제될 때 행의 데이터가 하위 테이블에서 사용되는 경우 FOREIGN KEY 제약 조건 실패로 인해 MySQL에서 오류가 발생합니다. 이는 "고객"과 "주문"이라는 두 테이블의 예를 사용하여 이해할 수 있습니다. 여기서 "customer"는 상위 테이블이고 "orders"는 하위 테이블입니다. 하위 테이블 "주문"에 사용된 "고객" 테이블의 행은 삭제할 수 없습니다. 아래 표시된 것처럼 상위 테이블에서 값을 삭제하여 시연할 수 있습니다. -

mysql> Select * from Customer;
+----+--------+
| id | name   |
+----+--------+
| 1  | Gaurav |
| 2  | Raman  |
| 3  | Harshit|
| 4  | Aarav  |
+----+--------+
4 rows in set (0.00 sec)

mysql> Select * from orders;
+----------+----------+------+
| order_id | product  | id   |
+----------+----------+------+
| 100      | Notebook | 1    |
| 110      | Pen      | 1    |
| 120      | Book     | 2    |
| 130      | Charts   | 2    |
+----------+----------+------+
4 rows in set (0.00 sec)
로그인 후 복사

이제 상위 테이블 "customer"에서 id = 1 또는 id = 2인 행을 삭제하려고 한다고 가정합니다. 하위 테이블 행), 외래 키 제약 조건이 실패했기 때문에 MySQL은 다음 오류를 발생시킵니다.

rreee

위 내용은 MySQL 상위 테이블에서 행을 삭제하면 어떻게 되나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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