数据库之 表与表之间的关系

来源:http://www.prospettivedarte.com 作者:计算机教程 人气:130 发布时间:2019-05-11
摘要:本节重点: 如何找出两张表之间的关系 表的三种关系  多对多关系举例 一、介绍 因为有foreign key的约束,使得两张表形成了三种了关系: 多对一 多对多 一对一 练习   二、重点理解

本节重点:

图片 1

  • 如何找出两张表之间的关系
  • 表的三种关系

 多对多关系举例

一、介绍

因为有foreign key的约束,使得两张表形成了三种了关系:

  • 多对一
  • 多对多
  • 一对一

练习

 

图片 2

二、重点理解如果找出两张表之间的关系

图片 3

分析步骤:
#1、先站在左表的角度去找
是否左表的多条记录可以对应右表的一条记录,如果是,则证明左表的一个字段foreign key 右表一个字段(通常是id)

#2、再站在右表的角度去找
是否右表的多条记录可以对应左表的一条记录,如果是,则证明右表的一个字段foreign key 左表一个字段(通常是id)

#3、总结:
#多对一:
如果只有步骤1成立,则是左表多对一右表
如果只有步骤2成立,则是右表多对一左表

#多对多
如果步骤1和2同时成立,则证明这两张表时一个双向的多对一,即多对多,需要定义一个这两张表的关系表来专门存放二者的关系

#一对一:
如果1和2都不成立,而是左表的一条记录唯一对应右表的一条记录,反之亦然。这种情况很简单,就是在左表foreign key右表的基础上,将左表的外键字段设置成unique即可

图片 4

 

图片 5

三、表的三种关系

(1)书和出版社

  一对多(或多对一):一个出版社可以出版多本书。看图说话。

  关联方式:foreign key

 图片 6

 

图片 7图片 8

create table press(
    id int primary key auto_increment,
    name varchar(20)
);

create table book(
    id int primary key auto_increment,
    name varchar(20),
    press_id int not null,
         constraint fk_book_press foreign key(press_id) references press(id)
    on delete cascade
    on update cascade
);

# 先往被关联表中插入记录
insert into press(name) values
('北京工业地雷出版社'),
('人民音乐不好听出版社'),
('知识产权没有用出版社')
;

# 再往关联表中插入记录
insert into book(name,press_id) values
('九阳神功',1),
('九阴真经',2),
('九阴白骨爪',2),
('独孤九剑',3),
('降龙十巴掌',2),
('葵花宝典',3)
;

查询结果:
mysql> select * from book;
 ---- ----------------- ---------- 
| id | name            | press_id |
 ---- ----------------- ---------- 
|  1 | 九阳神功        |        1 |
|  2 | 九阴真经        |        2 |
|  3 | 九阴白骨爪      |        2 |
|  4 | 独孤九剑        |        3 |
|  5 | 降龙十巴掌      |        2 |
|  6 | 葵花宝典        |        3 |
 ---- ----------------- ---------- 
6 rows in set (0.00 sec)

mysql> select * from press;
 ---- -------------------------------- 
| id | name                           |
 ---- -------------------------------- 
|  1 | 北京工业地雷出版社             |
|  2 | 人民音乐不好听出版社           |
|  3 | 知识产权没有用出版社           |
 ---- -------------------------------- 
3 rows in set (0.00 sec)

书和出版社(多对一)

 

(2)作者和书籍的关系

多对多:一个作者可以写多本书,一本书也可以有多个作者,双向的一对多,即多对多。看图说话。

关联方式:foreign key 一张新的表

图片 9

 

 

图片 10图片 11

# 创建被关联表author表,之前的book表在讲多对一的关系已创建
create table author(
    id int primary key auto_increment,
    name varchar(20)
);
#这张表就存放了author表和book表的关系,即查询二者的关系查这表就可以了
create table author2book(
    id int not null unique auto_increment,
    author_id int not null,
    book_id int not null,
    constraint fk_author foreign key(author_id) references author(id)
    on delete cascade
    on update cascade,
    constraint fk_book foreign key(book_id) references book(id)
    on delete cascade
    on update cascade,
    primary key(author_id,book_id)
);
#插入四个作者,id依次排开
insert into author(name) values('egon'),('alex'),('wusir'),('yuanhao');

# 每个作者的代表作
egon: 九阳神功、九阴真经、九阴白骨爪、独孤九剑、降龙十巴掌、葵花宝典
alex: 九阳神功、葵花宝典
wusir:独孤九剑、降龙十巴掌、葵花宝典
yuanhao:九阳神功

# 在author2book表中插入相应的数据

insert into author2book(author_id,book_id) values
(1,1),
(1,2),
(1,3),
(1,4),
(1,5),
(1,6),
(2,1),
(2,6),
(3,4),
(3,5),
(3,6),
(4,1)
;
# 现在就可以查author2book对应的作者和书的关系了
mysql> select * from author2book;
 ---- ----------- --------- 
| id | author_id | book_id |
 ---- ----------- --------- 
|  1 |         1 |       1 |
|  2 |         1 |       2 |
|  3 |         1 |       3 |
|  4 |         1 |       4 |
|  5 |         1 |       5 |
|  6 |         1 |       6 |
|  7 |         2 |       1 |
|  8 |         2 |       6 |
|  9 |         3 |       4 |
| 10 |         3 |       5 |
| 11 |         3 |       6 |
| 12 |         4 |       1 |
 ---- ----------- --------- 
12 rows in set (0.00 sec)

作者与书籍关系(多对多)

 

 

(3)用户和博客

  一对一:一个用户只能注册一个博客,即一对一的关系。看图说话

关联方式:foreign key unique

 

图片 12

 

 

图片 13图片 14

#例如: 一个用户只能注册一个博客

#两张表: 用户表 (user)和 博客表(blog)
# 创建用户表
create table user(
    id int primary key auto_increment,
    name varchar(20)
);
# 创建博客表
create table blog(
    id int primary key auto_increment,
    url varchar(100),
    user_id int unique,
    constraint fk_user foreign key(user_id) references user(id)
    on delete cascade
    on update cascade
);
#插入用户表中的记录
insert into user(name) values
('alex'),
('wusir'),
('egon'),
('xiaoma')
;
# 插入博客表的记录
insert into blog(url,user_id) values
('http://www.cnblog/alex',1),
('http://www.cnblog/wusir',2),
('http://www.cnblog/egon',3),
('http://www.cnblog/xiaoma',4)
;
# 查询wusir的博客地址
select url from blog where user_id=2;

用户和博客(一对一)

 

三、多对多(多条记录对应多条记录)

运行结果截图:

 

图片 15

===========例子一:用户表和管理员表=========
先建被关联的表
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
);
insert into user(name) values('susan1'),
                             ('susan2'),
                             ('susan3'),
                             ('susan4'),
                             ('susan5'),
                             ('susan6');
insert into admin(user_id,password) values(4,'sds156'),
                                          (2,'531561'),
                                          (6,'f3swe');
========例子二:学生表和客户表=========
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
);
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);

      2.在创建关联表,关联字段一定保证是要有重复的。

管理员关联用户

联合唯一:unique(book_id,author_id)

运行结果截图:

例子二:学生表和客户表

-- 主机表
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');

-- 业务线表
create table business(
id int primary key auto_increment,
business varchar(20) not null unique
);
insert into business(business) values
                                        ('轻松贷'),
                                        ('随便花'),
                                        ('大富翁'),
                                        ('穷一生');

-- 建立host和business关系表
CREATE TABLE host2business(
id int not null unique auto_increment,
host_id int not null ,
business_id int not NULL ,
PRIMARY KEY(host_id,business_id),
foreign key(host_id) references host(id),
FOREIGN KEY(business_id) REFERENCES business(id)
);


insert into host2business(host_id,business_id) values
                                                        (1,1),
                                                        (1,2),
                                                        (1,3),
                                                        (2,2),
                                                        (2,3),
                                                        (3,4);

图片 16图片 17

二、一对一

图片 18

 

 

图片 19

1、先确立关系

本文由皇牌天下投注网发布于计算机教程,转载请注明出处:数据库之 表与表之间的关系

关键词:

最火资讯