多表查询和外键关联
实际开发中,一个项目通常需要很多张表才能完成。例如,一个商城项目就需要分类表,商品表,订单表等多张表。且这些表的数据之间存在一定的关系,接下来我们将在单表的基础上,一起学习多表方面的知识。
多表关系
一对一关系
一对多/多对一关系
多对多关系
分析:一个学生可以选择很多门课程,一个课程也可以被很多学生选择,原则:多对多关系实际需要借助第三张中间表。中间表至少包含两个字段,将多对多的关系,拆成一对多的关系,中间表至少要有两个外键,这两个外键分别指向原来的那张两张表的主键
外键约束
介绍
MySQL外键约束(FOREIGN KEY)是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。
外键用来建立主表与从表的关联关系,为两个表的数据简历连接,约束两个表中数据的一致性和完整性。比如,一个水果摊,只有苹果,桃子,李子,西瓜等4种水果,那么,你来到水果摊要买水果只能选择苹果,桃子,李子和西瓜,其它的水果都是不能购买的。
特点
创建外键约束-第一种方式
在create table语句中,通过foreign key关键字来指定外键,具体的语法格式如下:
[constraint<外键名>] foreign key 字段名[,字段名2,…] references<主键名> 主键列1 [,主键列2,…]
实现:
create database mydb3;
use mydb3;
— 创建部门表
create table if not exists dept(
depton varchar(20) primary key, — 部门号
name varchar(20) –部门名字
);
create table if not exists emp(
eid varchar(20) primary key,– 员工编号
ename varchar(20), — 员工名字
age int,– 员工年龄
dept_id varchar(20), —员工所属部门
constaraint emp_fk foreign key(dept_id) references dept(deptno) — 外键约束
);
外键约束
create database mydb3;
use mydb3;
创建部门表
create table if not exists dept(
deptno varchar(20) primary key, — 部门编号
name varchar(20) — 部门名字
);
创建员工表,并创建外键约束 –方式1
[constraint<外键名> ] foreign key 字段名 [,字段名2,…] references<主表名> 主键列1[,主键列2,…]
create table if not exists emp(
eid varchar(20) primary key, — 员工编号
ename varchar(20),– 员工姓名
age int ,– 员工年龄
dept_id varchar(20), — 员工所属部门
constraint emp_fk foreign key (dept_id) references dept(deptno)
);
创建外键约束-第二种方式
外键约束也可以在修改表时添加,但是添加外键约束的前提是:才表中外键列中的数据必须与主表中主键列中的数据一致或者是没有数据。
alter table <数据表名> add constarint <外键名> foreign key(<列名>) references <主表名>(<列名>);
在外键约束下的数据操作
删除外键约束
多对多关系
多表联合查询
内连接查询
外连接查询
子查询
①:基本子查询
②:all关键字
③:Any和some
④:in
⑤:Exists
自关联查询
原文地址:https://blog.csdn.net/weixin_62458944/article/details/132509326
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_33082.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!