Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

MySQL 상위 테이블에서 행을 삭제하면 어떻게 됩니까?

<시간/>

부모 테이블에서 행을 삭제하는 동안 해당 행의 데이터가 자식 테이블에서 사용되면 MySQL은 FOREIGN KEY 제약 조건의 실패로 인해 오류를 발생시킵니다. 'customer'와 'orders'라는 두 개의 테이블을 예로 들어 이해할 수 있습니다. 여기서 'customer'는 상위 테이블이고 'orders'는 하위 테이블입니다. '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은 외부 오류로 인해 다음과 같은 오류를 발생시킵니다. 키 제약 조건.

mysql> Delete from customer where id = 1;
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`query`.`orders`, CONSTRAINT `orders_ibfk_1` FOREIGN KEY (`id`)REFERENCES `customer` (`id`))

mysql> Delete from customer where id = 2;
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`query`.`orders`, CONSTRAINT `orders_ibfk_1` FOREIGN KEY (`id`)REFERENCES `customer` (`id`))