MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

MySQLの親テーブルから行を削除するとどうなりますか?


親テーブルから行を削除しているときに、その行のデータが子テーブルで使用されている場合、FOREIGN KEY制約が失敗したため、MySQLはエラーをスローします。これは、「customer」と「orders」という名前の2つのテーブルの例で理解できます。ここで、「customer」は親テーブルであり、「orders」は子テーブルです。子テーブルの「orders」で使用されている行を「customer」テーブルから削除することはできません。次のように親テーブルから値を削除することで実証できます-

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)

ここで、id=1またはid=2の行(両方の行が子テーブルで使用されているため)を親テーブル'customer'から削除しようとすると、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`))

  1. MySQLテーブルから値を削除するストアドプロシージャを作成するにはどうすればよいですか?

    IN演算子を使用してストアドプロシージャを作成し、MySQLテーブルから値を削除できます。理解できるように、次のデータを持つ「student_info」という名前のテーブルの例を取り上げています- mysql> Select * from student_info; +------+---------+------------+------------+ | id   | Name    | Address    | Subject    | +------+---------+------------+-------

  2. 単一のクエリでIN()を使用してMySQLテーブルからレコードを削除する

    テーブルを作成しましょう- mysql> create table DemoTable1922    (    StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY,    StudentName varchar(20)    ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1922(StudentNa