Select*fromCustomer;+----+--------+|id|name |+----+-- - -----+|1"/> Select*fromCustomer;+----+--------+|id|name |+----+-- - -----+|1">
상위 테이블에서 행이 삭제될 때 행의 데이터가 하위 테이블에서 사용되는 경우 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!