1. Foreign key function: MySQL uses foreign key constraints to ensure the integrity and accuracy of data between tables. 2. Conditions for using foreign keys
3. Create Grammar
4. Case Demonstration CASCADE constraint mode 1. Create the power table (parent table) country create table country ( id int not null, name varchar(30), primary key(id) ); 2. Insert records insert into country values(1,'Western Europe'); insert into country values(2,'Maya'); insert into country values(3,'Sicily'); 3. Create a arms table (sub-table) and establish constraints create table solider ( id int not null, name varchar(30), country_id int, primary key(id), foreign key(country_id) references country(id) on delete cascade on update cascade, ); 4. Reference integrity test insert into solider values(1,'Western European trainee infantry',1); #insert successfully insert into solider values(2,'Maya short spearman',2); #insert successfully insert into solider values(3,'Sicily Norman Knights',3) #insert successfullyinsert into solider values(4,'French Swordsman',4); #Insert failed because there is no faction with id 4 in the country table. 5. Constraint method test insert into solider values(4, 'Maya Tiger Warriors', 2); #Successfully inserted delete from country where id=2; #This will cause the records with id 2 and 4 in the solider table to be deleted at the same time, because this faction no longer exists in the parent table, so the corresponding arms will naturally disappear update country set id=8 where id=1; #As a result, all records in the solider table with country_id 1 will also be modified to 8 With SET NULL constraint 1. Create a soldier table (sub-table) and establish a constraint relationship drop table if exists solider; create table solider( id int not null, name varchar(30), country_id int, primary key(id), foreign key(country_id) references country(id) on delete set null on update set null, ); 2. Reference integrity test insert into solider values(1,'Western European trainee infantry',1); #insert successfully insert into solider values(2,'Maya short spearman',2); #insert successfully insert into solider values(3,'Sicily Norman Knights',3) #insert successfullyinsert into solider values(4,'French Swordsman',4); #Insert failed because there is no faction with id 4 in the country table. 3. Constraint method test insert into solider values (4, 'Sicilian Archer', 3); #Successfully inserted delete from country where id=3; #This will cause the records with id 3 and 4 in the solider table to be set to NULL update country set id=8 where id=1; # Causes all records in the solider table where country_id is 1 to be set to NULL With NO ACTION or RESTRICT mode (default) 1. Create a soldier table (sub-table) and establish a constraint relationship drop table if exists solider; create table solider( id int not null, name varchar(30), country_id int, primary key(id), foreign key(country_id) references country(id) on delete RESTRICT on update RESTRICT, ); 2. Reference integrity test insert into solider values(1,'Western European trainee infantry',1); #insert successfully insert into solider values(2,'Maya short spearman',2); #insert successfully insert into solider values(3,'Sicily Norman Knights',3) #insert successfullyinsert into solider values(4,'French Swordsman',4); #Insert failed because there is no faction with id 4 in the country table 3. Constraint method test insert into solider values(4, 'Western European Knights', 1); #Successfully inserted delete from country where id=1; #An error occurred. There are related records in the child table, so the corresponding records in the parent table cannot be deleted. That is, the arms table also has arms belonging to Western Europe, so the Western European forces in the parent table cannot be deleted alone. update country set id=8 where id=1; #Error, there are related records in the child table, so the parent table cannot be modified The above is the detailed explanation of MySQL foreign key constraints. For more information about MySQL foreign key constraints, please pay attention to other related articles on 123WORDPRESS.COM! You may also be interested in:
|
<<: Detailed tutorial on installing CUDA9.0 on Ubuntu16.04
>>: Detailed explanation of vue.js dynamic components
Methods for changing passwords before MySQL 5.7: ...
Preface When I was typing my own personal blog, I...
mysql set to case insensitive Windows Go to the d...
For a website, it is the most basic function. So l...
There are many servers that can host static websi...
1: Define a stored procedure to separate strings ...
Table of contents Preface text Primitive types Pr...
Features of SSHFS: Based on FUSE (the best usersp...
The cascading drop-down menu developed in this ex...
There are many commands used in the system, so ho...
1. Absolute path First of all, on the local compu...
I usually use nginx as a reverse proxy for tomcat...
I used the Mysql FIND_IN_SET function in a projec...
Content 1. Give readers a reason to stay. Make the...
Talk about the scene Send Email Embedding HTML in...