Maison >base de données >tutoriel mysql >Quelle est la relation entre les tables MySQL ? Diverses relations entre les tables
Le contenu de cet article est de présenter la relation entre les tables MySQL et les tables ? Diverses relations entre les tables. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il vous sera utile.
Relation entre les tables
表1 foreign key 表2 则表1的多条记录对应表2的一条记录,即多对一 利用foreign key的原理我们可以制作两张表的多对多,一对一关系多对多: 表1的多条记录可以对应表2的一条记录 表2的多条记录也可以对应表1的一条记录 一对一: 表1的一条记录唯一对应表2的一条记录,反之亦然 分析时,我们先从按照上面的基本原理去套,然后再翻译成真实的意义,就很好理解了
1. Déterminez d'abord la relation
Trouvez plus D'un côté, écrivez les champs associés du côté plusieurs
Un-à-plusieurs
Plusieurs-à-un ou un-à-plusieurs (plusieurs entrées dans le tableau de gauche L'enregistrement correspond au seul enregistrement du tableau de droite)
Choses à noter :
1 Créez d'abord la table associée en vous assurant. que les champs de la table associée doivent être uniques.
2. Lors de la création d'une table associée, les champs associés doivent être dupliqués.
Exemple :
Ceci est un exemple de livre et d'éditeur. Le livre doit être associé à l'éditeur (plusieurs livres peuvent l'être. une publication (une maison d’édition peut aussi avoir plusieurs livres).
Quiconque s'associe à quelqu'un qui est responsable doit suivre les normes de qui.
Créer un tableau
书要关联出版社 被关联的表 create table press(id int primary key auto_increment, name char(20)); 关联的表 create table book( book_id int primary key auto_increment, book_name varchar(20), book_price int, press_id int, constraint Fk_pressid_id foreign key(press_id) references press(id) on delete cascade on update cascade );
Insérer des données
insert into press(name) values('新华出版社'), ('海燕出版社'), ('摆渡出版社'), ('大众出版社'); insert into book(book_name,book_price,press_id) values('Python爬虫',100,1), ('Linux',80,1), ('操作系统',70,2), ('数学',50,2), ('英语',103,3), ('网页设计',22,3);
Résultat en cours
1 En tête-à-tête
Exemple 1 :
Utilisateur et administrateur (seuls les administrateurs peuvent se connecter, un administrateur correspond à un utilisateur)
Utilisateur associé à l'administrateur
Créer une table
先建被关联的表 create table user( id int primary key auto_increment, #主键自增name char(10) ); 再建关联表 create table admin( id int primary key auto_increment, user_id int unique, password varchar(16), foreign key(user_id) references user(id) on delete cascade on update cascade );
Insérer des données
insert into user(name) values('susan1'),('susan2'),('susan3'),('susan4')('susan5'),('susan6'); insert into admin(user_id,password) values(4,'sds156'),(2,'531561'),(6,'f3swe');
Exécuter les résultats
Exemple 2 :
Table des étudiants et table des clients
Créer une table
create table customer( id int primary key auto_increment, name varchar(10), qq int unique, phone int unique ); create table student1( sid int primary key auto_increment, course char(20), class_time time, cid int unique, foreign key(cid) references customer(id) on delete cascade on update cascade );
Insérer des données
insert into customer(name,qq,phone) values('小小',13564521,11111111),('嘻哈',14758254,22222222),('王维',44545522,33333333),('胡军',545875212,4444444),('李希',145578543,5555555),('李迪',754254653,8888888),('艾哈',74545145,8712547),('啧啧',11147752,7777777); insert into student1(course,class_time,cid) values('python','08:30:00',3),('python','08:30:00',4),('linux','08:30:00',1),('linux','08:30:00',7);
Résultat d'exécution
Plusieurs à plusieurs
Livre et auteur (nous pouvons créer une autre table pour stocker la relation entre les tables livre et auteur)
Définir book_id et author_id pour qu'ils soient conjointement uniques
Uniquely unique: unique(book_id, author_id)
Clé primaire commune :alter table t1 ajouter une clé primaire (id,avg)
Plusieurs à plusieurs : un auteur peut écrire plusieurs livres, et un livre peut également avoir plusieurs auteurs, dans les deux sens, un à plusieurs, c'est-à-dire Plusieurs paires de
méthodes d'association : clé étrangère + une nouvelle table
Exemple :
Créer un tableau
========书和作者,另外在建一张表来存书和作者的关系 #被关联的 create table book1( id int primary key auto_increment, name varchar(10), price float(3,2) ); #========被关联的 create table author( id int primary key auto_increment, name char(5) ); #========关联的 create table author2book( id int primary key auto_increment, book_id int not null, author_id int not null, unique(book_id,author_id), foreign key(book_id) references book1(id) on delete cascade on update cascade, foreign key(author_id) references author(id) on delete cascade on update cascade );
Insérer des données
insert into book1(name,price) values('九阳神功',9.9), ('葵花宝典',9.5), ('辟邪剑谱',5), ('降龙十巴掌',7.3); insert into author(name) values('egon'),('e1'),('e2'),('e3'),('e4'); insert into author2book(book_id,author_id) values(1,1),(1,4),(2,1),(2,5),(3,2),(3,3),(3,4),(4,5);
Exemple de relation plusieurs-à-plusieurs
Table utilisateur, groupe d'utilisateurs, table hôte
Créer trois tables
-- 用户表 create table user (id int primary key auto_increment,username varchar(20) not null,password varchar(50) not null); insert into user(username,password) values('egon','123'),('root',147),('alex',123),('haiyan',123),('yan',123); -- 用户组表 create table usergroup(id int primary key auto_increment,groupname varchar(20) not null unique); insert into usergroup(groupname) values('IT'),('Sale'),('Finance'),('boss'); -- 主机表 CREATE TABLE host(id int primary key auto_increment,ip CHAR(15) not NULL UNIQUE DEFAULT '127.0.0.1'); insert into host(ip) values('172.16.45.2'),('172.16.31.10'),('172.16.45.3'),('172.16.31.11'),('172.10.45.3'), ('172.10.45.4'),('172.10.45.5'),('192.168.1.20'),('192.168.1.21'),('192.168.1.22'),('192.168.2.23'),('192.168.2.223'), ('192.168.2.24'),('192.168.3.22'),('192.168.3.23'),('192.168.3.24');
Établir des relations
-- 建立user和usergroup的关系表 create table user2usergroup( id int not NULL UNIQUE auto_increment, user_id int not null, group_id int not NULL, PRIMARY KEY(user_id,group_id), foreign key(user_id) references user(id) ON DELETE CASCADE on UPDATE CASCADE , foreign key(group_id) references usergroup(id) ON DELETE CASCADE on UPDATE CASCADE ); insert into user2usergroup(user_id,group_id) values(1,1),(1,2),(1,3),(1,4),(2,3),(2,4),(3,4); -- 建立user和host的关系 create table user2host( id int not null unique auto_increment, user_id int not null, host_id int not null, primary key(user_id,host_id), foreign key(user_id) references user(id), foreign key(host_id) references host(id) ); insert into user2host(user_id,host_id) values(1,1),(1,2),(1,3),(1,4),(1,5),(1,6),(1,7),(1,8),(1,9),(1,10),(1,11),(1,12),(1,13),(1,14),(1,15),(1,16),(2,2),(2,3),(2,4),(2,5),(3,10),(3,11),(3,12);
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!