MySQL(多对多、一对多、一对一)

多对多:

例如:
一个学生可以学多门课程
一门课程可以有多个学生: 多对多

创建学生表

create table students(
id int primary key auto_increment,
name varchar(20) not null,
gender char(10)
);

创建课程表:

create table course(
id int primary key auto_increment,
course_name varchar (20) not null
);

创建关系表:

create table std_cou(
id int primary key auto_increment,
sid int,
cid int,
-- 创建外键
CONSTRAINT fk_sid FOREIGN KEY(sid) references students(id),
CONSTRAINT fk_cid FOREIGN KEY(cid) references course(id)
);

一对多:在多的一方 建立外键

例如:
一个班级对应多个学生:

班级表:

create table class(
id int primary  key auto_increment,
classnum VARCHAR(20) not null
);

新的学生表:

create table student(
id int primary key auto_increment,
name varchar(20) not null,
gender char(10),
class_id int,
-- 创建外键
CONSTRAINT fk_class FOREIGN key (class_id) REFERENCES class(id)       
);

一对一:

例如:
一个老师教一门课
一门课对应一个老师
创建课程表:

create table courses(
id int PRIMARY key  ,
cour_name VARCHAR(20) not null
);

创建教室表:

create table teacher(
id int PRIMARY key auto_increment,
tea_num char(11) not null UNIQUE,
age int ,
-- 添加外键  用主键去关联主键
 CONSTRAINT fk_cour_tea FOREIGN KEY (id) REFERENCES courses(id)
);
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值