Heim > Datenbank > MySQL-Tutorial > Welche Beziehung besteht zwischen MySQL-Tabellen? Verschiedene Beziehungen zwischen Tabellen

Welche Beziehung besteht zwischen MySQL-Tabellen? Verschiedene Beziehungen zwischen Tabellen

青灯夜游
Freigeben: 2018-10-27 17:18:05
nach vorne
6391 Leute haben es durchsucht

Der Inhalt dieses Artikels besteht darin, die Beziehung zwischen MySQL-Tabellen und Tabellen vorzustellen. Verschiedene Beziehungen zwischen Tabellen. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird Ihnen hilfreich sein.

Die Beziehung zwischen Tabellen

表1 foreign key 表2
则表1的多条记录对应表2的一条记录,即多对一

利用foreign key的原理我们可以制作两张表的多对多,一对一关系多对多:
    表1的多条记录可以对应表2的一条记录
    表2的多条记录也可以对应表1的一条记录

一对一:
    表1的一条记录唯一对应表2的一条记录,反之亦然

分析时,我们先从按照上面的基本原理去套,然后再翻译成真实的意义,就很好理解了
Nach dem Login kopieren

1. Bestimmen Sie zuerst die Beziehung

2. Finden Sie die Gruppe mit mehr, schreiben Sie die zugehörigen Felder auf der Viele-Seite

eins-zu-viele

viele-zu-eins oder eins-zu-viele (mehrere Datensätze). in der linken Tabelle entsprechen dem einzigen Datensatz in der Tabelle rechts)

Zu beachtende Dinge:

  • 1. Erstellen Sie zuerst die zugehörige Tabelle und stellen Sie sicher, dass die Felder der zugehörigen Tabelle muss eindeutig sein.

  • 2. Beim Erstellen einer Bezugstabelle müssen die Bezugsfelder dupliziert werden.

Beispiel:

Dies ist ein Beispiel für ein Buch und ein Verlag, der mit dem Verlag verknüpft sein sollte (es können mehrere Bücher sein). eine Publikation (ein Verlag kann auch viele Bücher haben).

Wer mit demjenigen zusammenarbeitet, der verantwortlich ist, muss sich an dessen Standards halten.

  • Tabelle erstellen

书要关联出版社
被关联的表
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
);
Nach dem Login kopieren
  • Daten einfügen

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);
Nach dem Login kopieren
  • Laufergebnisse

Eins-zu-eins

Beispiel 1:

Benutzer und Administratoren (nur Administratoren können sich anmelden, ein Administrator entspricht einem Benutzer)

Dem Administrator zugeordneter Benutzer

  • Tabelle erstellen

先建被关联的表
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
);
Nach dem Login kopieren
  • Daten einfügen

insert into user(name) values('susan1'),('susan2'),('susan3'),('susan4')('susan5'),('susan6');

insert into admin(user_id,password) values(4,'sds156'),(2,'531561'),(6,'f3swe');
Nach dem Login kopieren
  • Laufergebnisse

Beispiel 2:

Schülertisch und Kundentisch

  • Tisch erstellen

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
);
Nach dem Login kopieren
  • Daten einfügen

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);
Nach dem Login kopieren
  • Laufergebnis

Many-to-many

Buch und Autor (wir können eine weitere Tabelle erstellen, um die Beziehung zwischen den Buch- und Autorentabellen zu speichern)

Zum Festlegen der Buch-ID und der Autor_ID sind so eingestellt, dass sie gemeinsam eindeutig sind

Eindeutig eindeutig: unique(book_id, author_id)

Gemeinsamer Primärschlüssel: Tabelle t1 ändern Primärschlüssel hinzufügen(id,durchschn )

Viele-zu-viele: Ein Autor kann mehrere Bücher schreiben, und ein Buch kann auch mehrere Autoren haben, bidirektional eins-zu-viele, also viele Paare

Beziehungsmethode: Fremdschlüssel+eine neue Tabelle

Beispiel:

  • Tabelle erstellen

========书和作者,另外在建一张表来存书和作者的关系
#被关联的
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
);
Nach dem Login kopieren
  • Daten einfügen

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);
Nach dem Login kopieren

Many-to-many-Beziehungsbeispiel

Benutzertabelle, Benutzergruppe, Hosttabelle

  • Drei Tabellen erstellen

-- 用户表
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');
Nach dem Login kopieren
  • Beziehung herstellen

-- 建立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);
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWelche Beziehung besteht zwischen MySQL-Tabellen? Verschiedene Beziehungen zwischen Tabellen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:cnblogs.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage