MySQL-4多表操作
MySQL-4多表操作
文章目录
- MySQL-4多表操作
- 多表关系
- 一对一
- 一对多/多对一
- 多对多
- 外键约束
- 介绍
- 特点
- 定义外键时,遵守下列规则
- 操作-创建外键约束
- 方式1-在创建表时设置外键约束
- 实现
- 方式2-在创建后设置外键约束
- 格式
- 实现
- 数据插入
- 删除数据
- 删除外键约束
- 格式
- 实现
- 多表联合查询
- 介绍
- 数据准备
- 注
- 创建部门表
- 创建员工表
- 准备查询数据
- 向部门表(dept3)中插入数据
- 向员工表(emp3)中插入数据
- 多表查询分类
- 交叉连接查询(产生笛卡儿积)
- 语法
- 实现
- 内连接查询
- 隐式内连接
- 显示内连接
- 操作
- 外连接查询
- 分类
- 左外连接:left outer join
- 操作
- 右外连接:right outer join
- 操作
- 满外连接:full outer join
- 操作
- 子查询
- 介绍
- 特点
- 操作
- 子查询中的关键字
- ALL关键字
- 格式
- 特点
- 操作
- ANY关键字和SOMY关键字
- 格式
- 特点
- 操作
- IN关键字
- 格式
- 特点
- 操作
- EXISTS关键字
- 格式
- 特点
- 操作
- 表自关联
- 概念
- 格式
- 操作
多表关系
一对一
- 在任一表中添加唯一外键,指向另一方主键,确保一对一关系。
- 一个学生只有一张身份证;一张身份证只能对应一学生。
- 一般一对一关系很少见,遇到一对一关系的表最好是合并表。
一对多/多对一
实现原则:在多的一方建立外键,指向一的一方的主键
部门和员工
- 分析:
- 一个部门有多个员工,
- 一个员工只能对应一个部门
多对多
- 原则:多对多关系实现需要借助第三张中间表。
- 中间表至少包含两个字段
- 将多对多的关系
- 拆成一对多的关系
- 中间表至少要有两个外键
- 这两个外键分别指向原来的那两张表的主键
- 中间表至少包含两个字段
- 学生和课程
- 分析:
- 一个学生可以选择很多门课程,
- 一个课程也可以被很多学生选择
外键约束
介绍
- MySQL 外键约束(FOREIGN KEY)是表的一个特殊字段,
- 经常与主键约束一起使用。
- 对于两个具有关联关系的表而言,
- 相关联字段中主键所在的表就是主表(父表),
- 外键所在的表就是从表(子表)。
- 外键用来建立主表与从表的关联关系,
- 为两个表的数据建立连接,
- 约束两个表中数据的一致性和完整性。
- 比如:
- 一个水果摊,只有苹果、桃子、李子、西瓜等 4 种水果,
- 那么,你来到水果摊要买水果就只能选择苹果、桃子、李子和西瓜,
- 其它的水果都是不能购买的。
特点
定义外键时,遵守下列规则
- 主表必须已经存在于数据库中
- 或者是当前正在创建的表。
- 必须为主表定义主键。
- 主键不能包含空值,但允许在外键中出现空值。
- 也就是说,只要外键的每个非空值出现在指定的主键中
- 这个外键的内容就是正确的。
- 在主表的表名后面指定列名或列名的组合。
- 这个列或列的组合必须是主表的主键或候选键。
- 外键中列的数目必须和主表的主键中列的数目相同。
- 外键中列的数据类型必须和主表主键中对应列的数据类型相同。
操作-创建外键约束
方式1-在创建表时设置外键约束
在 create table 语句中,通过 foreign key 关键字来指定外键,具体的语法格式如下:
[constraint <外键名>] foreign key 字段名 [,字段名2,…] references <主表名> 主键列1 [,主键列2,…]
实现
create database mydb3; -- 创建数据库
use mydb3;
-- 创建部门表
create table if not exists dept(deptno 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), -- 员工所属部门constraint emp_fk foreign key (dept_id) references dept (deptno) –- 外键约束
);
两个表的关系如下
点击【文件】–【新架构设计器】–把表拖进来,就可以看到主外键关系图
方式2-在创建后设置外键约束
- 外键约束也可以在修改表时添加,
- 但是添加外键约束的前提是:
- 从表中外键列中的数据必须与主表中主键列中的数据一致
- 或者是没有数据。
格式
alter table <数据表名> add constraint <外键名> foreign key(<列名>) references
<主表名> (<列名>);
实现
-- 创建部门表
create table if not exists dept2(deptno varchar(20) primary key , -- 部门号name varchar(20) -- 部门名字
);
-- 创建员工表
create table if not exists emp2(eid varchar(20) primary key , -- 员工编号ename varchar(20), -- 员工名字age int, -- 员工年龄dept_id varchar(20) -- 员工所属部门);
-- 创建外键约束
alter table emp2 add constraint dept_id_fk foreign key(dept_id) references dept2 (deptno);
数据插入
添加主表数据
-- 1、添加主表数据-- 注意必须先给主表添加数据
insert into dept values('1001','研发部');
insert into dept values('1002','销售部');
insert into dept values('1003','财务部');
insert into dept values('1004','人事部');
添加从表数据
-- 2、添加从表数据-- 注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列
insert into emp values('1','乔峰',20, '1001');
insert into emp values('2','段誉',21, '1001');
insert into emp values('3','虚竹',23, '1001');
insert into emp values('4','阿紫',18, '1002');
insert into emp values('5','扫地僧',35, '1002');
insert into emp values('6','李秋水',33, '1003');
insert into emp values('7','鸠摩智',50, '1003');
insert into emp values('8','天山童姥',60, '1005'); -- 不可以
删除数据
-- 3、删除数据/*注意:1:主表的数据被从表依赖时,不能删除,否则可以删除2: 从表的数据可以随便删除*/
delete from dept where deptno = '1001'; -- 不可以删除
delete from dept where deptno = '1004'; -- 可以删除
delete from emp where eid = '7'; -- 可以删除
删除外键约束
当一个表中不需要外键约束时,就需要从表中将其删除。外键一旦删除,就会解除主表和从表间的关联关系
格式
alter table <表名> drop foreign key <外键约束名>;
实现
alter table emp2 drop foreign key dept_id_fk;
多表联合查询
介绍
多表查询就是同时查询两个或两个以上的表,因为有时候我们在查看数据的时候,需要显示的数据来自多张表.
数据准备
注
外键约束对多表查询并无影响
创建部门表
use mydb3;-- 创建部门表
create table if not exists dept3(deptno varchar(20) primary key , -- 部门号name varchar(20) -- 部门名字
);
创建员工表
use mydb3;-- 创建员工表
create table if not exists emp3(eid varchar(20) primary key , -- 员工编号ename varchar(20), -- 员工名字age int, -- 员工年龄dept_id varchar(20) -- 员工所属部门
);
准备查询数据
向部门表(dept3)中插入数据
-- 给dept3表添加数据
insert into dept3 values('1001','研发部');
insert into dept3 values('1002','销售部');
insert into dept3 values('1003','财务部');
insert into dept3 values('1004','人事部');
向员工表(emp3)中插入数据
-- 给emp3表添加数据
insert into emp3 values('1','乔峰',20, '1001');
insert into emp3 values('2','段誉',21, '1001');
insert into emp3 values('3','虚竹',23, '1001');
insert into emp3 values('4','阿紫',18, '1001');
insert into emp3 values('5','扫地僧',85, '1002');
insert into emp3 values('6','李秋水',33, '1002');
insert into emp3 values('7','鸠摩智',50, '1002');
insert into emp3 values('8','天山童姥',60, '1003');
insert into emp3 values('9','慕容博',58, '1003');
insert into emp3 values('10','丁春秋',71, '1005');
多表查询分类
- 交叉连接查询
- 内连接查询
- 外连接查询
- 子查询
- 表自关联
交叉连接查询(产生笛卡儿积)
- 交叉连接查询返回被连接的两个表所有数据行的笛卡尔积
- 笛卡尔积可以理解为一张表的每一行去和另外一张表的任意一行进行匹配(两表行间匹配)
- 假如A表有m行数据,B表有n行数据,则返回m*n行数据
- 笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选
语法
select * from 表1,表2...;
实现
-- 交叉连接查询select * from dept3,emp3;
内连接查询
内连接查询求多张表的交集
使用关键字inner join -inner可以省略
隐式内连接
select * from A,B where 条件;
显示内连接
select * from A inner join B on 条件;
操作
-- 查询每个部门的所属员工
-- 隐式内连接
select * from dept3,emp3 where dept3.deptno = emp3.dept_id;-- 显示内连接
select * from dept3 inner join emp3 on dept3.deptno = emp3.dept_id;
-- 查询研发部和销售部的所属员工
-- 隐式内连接
select * from dept3,emp3 where dept3.deptno = emp3.dept_id and name in( '研发部','销售部');-- 显示内连接
select * from dept3 join emp3 on dept3.deptno = emp3.dept_id and name in( '研发部','销售部');
-- 查询每个部门的员工数,并升序排序
-- 隐式内连接
select deptno,count(1) as total_cnt from dept3,emp3 where dept3.deptno = emp3.dept_id group by deptno order by total_cnt;-- 显示内连接
select deptno,count(1) as total_cnt from dept3 join emp3 on dept3.deptno = emp3.dept_id group by deptno order by total_cnt;注意:count(1)中的【1】可以用name代替,1只是数据库中表的列的顺序
-- 查询人数大于等于3的部门,并按照人数降序排序
-- 隐式内连接
select deptno,count(1) as total_cnt from dept3,emp3 where dept3.deptno = emp3.dept_id group by deptno having total_cnt >= 3 order by total_cnt desc;-- 显示内连接
select deptno,count(1) as total_cnt from dept3 join emp3 on dept3.deptno = emp3.dept_id group by deptno having total_cnt >= 3 order by total_cnt desc;
外连接查询
分类
- 左外连接
- 右外连接
- 满外连接
使用关键字outer join --outer 可以省略
左外连接:left outer join
以左边的表为主,左边表的信息全部都有
select * from A left outer join B on 条件;
操作
-- 外连接查询
-- 查询哪些部门有员工,哪些部门没有员工
use mydb3;
select * from dept3 left outer join emp3 on dept3.deptno = emp3.dept_id;
右外连接:right outer join
以右边的表为主,右边表的信息全部都有
select * from A right outer join B on 条件;
操作
-- 查询哪些员工有对应的部门,哪些没有
select * from dept3 right outer join emp3 on dept3.deptno = emp3.dept_id;
满外连接:full outer join
两个表的信息都有
select * from A full outer join B on 条件;
操作
-- 使用union关键字实现左外连接和右外连接的并集
select * from dept3 left outer join emp3 on dept3.deptno = emp3.dept_id
union
select * from dept3 right outer join emp3 on dept3.deptno = emp3.dept_id;
子查询
介绍
- 子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,
- 从而一起完成复杂查询的一种编写形式,
- 通俗一点就是包含select嵌套的查询。
特点
子查询返回数据类型4种
1.单行单列:
- 返回的是一个具体列的内容,
- 可以理解为一个单值数据;
2.单行多列:
返回一行数据中多个列的内容;
3.多行单列:
- 返回多行记录之中同一列的内容,
- 相当于给出了一个操作范围;
4.多行多列:
查询返回的结果是一张临时表
操作
-- 查询年龄最大的员工信息,显示信息包含员工号、员工名字,员工年龄
select eid,ename,age from emp3 where age = (select max(age) from emp3);-- 查询年研发部和销售部的员工信息,包含员工号、员工名字
select eid,ename,t.name from emp3 where dept_id in (select deptno,name from dept3 where name = '研发部' or name = '销售部') ;-- 查询研发部20岁以下的员工信息,包括员工号、员工名字,部门名字
select eid,age,ename,name from (select * from dept where name = '研发部 ')t1,(select * from emp3 where age <20)t2
子查询中的关键字
ALL关键字
格式
select ... from ... where c>all(查询语句)
-- 等价于
select ... from ... where c>result1 and c>result2 and c>result3;
特点
- ALL:
- 与子查询返回的所有值比较为true 则返回true
- ALL可以与**=、>、>=、<、<=、<>**结合是来使用,
- 分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的所有数据。
- ALL表示指定列中的值必须要大于子查询集的每一个值,
- 即必须要大于子查询集的最大值
- 如果是小于号即小于子查询集的最小值。
- 同理可以推出其它的比较运算符的情况。
操作
-- 查询年龄大于‘1003’部门所有年龄的员工信息
select * from emp3 where age > all(select age from emp3 where dept_id = '1003’);
-- 查询不属于任何一个部门的员工信息
select * from emp3 where dept_id != all(select deptno from dept3);
ANY关键字和SOMY关键字
格式
select ... from ... where c>any(查询语句)
--等价于
select ... from ... where c>result1 or c>result2 or c>result3;
特点
- ANY:与子查询返回的任何值比较为true 则返回true
- ANY可以与=、>、>=、<、<=、<>结合是来使用
- 分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的任何一个数据。
- 表示制定列中的值要大于子查询中的任意一个值
- 即必须要大于子查询集中的最小值。
- 同理可以推出其它的比较运算符的情况。
- SOME和ANY的作用一样
- SOME可以理解为ANY的别名
操作
-- 查询年龄大于‘1003’部门任意一个员工年龄的员工信息
select * from emp3 where age > all(select age from emp3 where dept_id = '1003’);
IN关键字
格式
select ... from ... where c in(查询语句)
-- 等价于
select ... from ... where c=result1 or c=result2 or c=result3;
特点
- IN关键字,用于判断某个记录的值,是否在指定的集合中
- 在IN关键字前边加上not可以将条件反过来
操作
-- 查询研发部和销售部的员工信息,包含员工号、员工名字
select eid,ename from emp3 where dept_id in (select deptno from dept3 where name = '研发部' or name = '销售部') ;
EXISTS关键字
格式
select ... from ... where exists(查询语句)
特点
- 该子查询如果“有数据结果”(至少返回一行数据),
- 则该EXISTS() 的结果为“true”
- 外层查询执行
- 该子查询如果“没有数据结果”(没有任何数据返回),
- 则该EXISTS()的结果为“false”
- 外层查询不执行
- EXISTS后面的子查询不返回任何实际数据,
- 只返回真或假
- 当返回真时 where条件成立
- 注意,EXISTS关键字,比IN关键字的运算效率高
- 因此,在实际开发中,特别是大数据量时,推荐使用EXISTS关键字
操作
-- 查询公司是否有大于60岁的员工,有则输出
select * from emp3 a where exists(select * from emp3 b where a.age > 60);
-- 查询有所属部门的员工信息
select * from emp3 a where exists(select * from dept3 b where a.dept_id = b.deptno);
表自关联
概念
- MySQL有时在信息查询时需要进行对表自身进行关联查询,
- 即一张表自己和自己关联,一张表当成多张表来用。
- 注意自关联时表必须给表起别名。
格式
select 字段列表 from 表1 a, 表1 b where 条件;
或
select 字段列表 from 表1 a [left] join 表1 b on 条件;
操作
创建表
-- 创建表,并建立自关联约束
use mydb3;
create table t_sanguo(eid int primary key ,ename varchar(20),manager_id int,foreign key (manager_id) references t_sanguo (eid) -- 添加自关联约束
);
添加数据
-- 添加数据
insert into t_sanguo values(1,'刘协',NULL);
insert into t_sanguo values(2,'刘备',1);
insert into t_sanguo values(3,'关羽',2);
insert into t_sanguo values(4,'张飞',2);
insert into t_sanguo values(5,'曹操',1);
insert into t_sanguo values(6,'许褚',5);
insert into t_sanguo values(7,'典韦',5);
insert into t_sanguo values(8,'孙权',1);
insert into t_sanguo values(9,'周瑜',8);
insert into t_sanguo values(10,'鲁肃',8);
进行关联查询
-- 进行关联查询
-- 1.查询每个三国人物及他的上级信息,如: 关羽 刘备
select * from t_sanguo a, t_sanguo b where a.manager_id = b.eid;
这节我们介绍了多表操作中的各种操作,包括多表关系、外键约束、多表联合查询、子查询和自关联查询等
(20),
manager_id int,
foreign key (manager_id) references t_sanguo (eid) – 添加自关联约束
);
添加数据
– 添加数据
insert into t_sanguo values(1,‘刘协’,NULL);
insert into t_sanguo values(2,‘刘备’,1);
insert into t_sanguo values(3,‘关羽’,2);
insert into t_sanguo values(4,‘张飞’,2);
insert into t_sanguo values(5,‘曹操’,1);
insert into t_sanguo values(6,‘许褚’,5);
insert into t_sanguo values(7,‘典韦’,5);
insert into t_sanguo values(8,‘孙权’,1);
insert into t_sanguo values(9,‘周瑜’,8);
insert into t_sanguo values(10,‘鲁肃’,8);
进行关联查询
– 进行关联查询
– 1.查询每个三国人物及他的上级信息,如: 关羽 刘备
select * from t_sanguo a, t_sanguo b where a.manager_id = b.eid;
[外链图片转存中...(img-m3Isz1Qp-1641557915816)]这节我们介绍了多表操作中的各种操作,包括多表关系、外键约束、多表联合查询、子查询和自关联查询等
MySQL-4多表操作相关推荐
- mysql配置——库表操作、用户操作
mysql----库表操作 ## 列出所有的库 mysql> show databases; +--------------------+ | Database | +--- ...
- 95.第十九章 MySQL数据库 -- 单表操作(五)
3.7 DQL语句 3.7.1 单表操作 官方帮助:https://dev.mysql.com/doc/refman/8.0/en/select.html 语法: SELECT[ALL | DISTI ...
- mysql的数据表操作
1.创建数据表 在创建数据表之前,要用use <数据库名>指定在哪个数据库中操作. 1.1创建表的语法格式 创建数据表语句为,其中[]中的表示可选 create table <表名& ...
- MySql随笔part3 表操作
一:什么是表 表(table): 表似一种结构化的文件,可用来存储某种特定类型的数据.表中的一条记录有对应的标题,标题称之为表的字段 二:创建表 1 create table table_name( ...
- mysql的多表操作_Mysql-多表连接的操作和用法
一.介绍 本节主题 多表连接查询 复合条件连接查询 子查询 准备表 #建表 create table dep( id int, name varchar(20) ); create table emp ...
- mysql宠物种类表,mysql中的表操作
------------恢复内容开始------------ 创建数据库 create database 数据库名 切换数据库 use 数据库名 建表: create table 表名 ( 字段名1, ...
- mysql datatable_MySQL-数据表操作
1.打开数据库 语法:USE 数据库名称: SELECT DATABASE();---查询当前使用的数据库 2.创建数据表 语法:CREATE TABLE [IF NOT EXITS] table_n ...
- mysql三:表操作
阅读目录 一 存储引擎介绍 二 表介绍 三 创建表 四 查看表结构 五 数据类型 六 表完整性约束 七 修改表ALTER TABLE 八 复制表 九 删除表 一 存储引擎介绍 存储引擎即表类型,mys ...
- mysql 数据库之表操作
一.表与表之间建关系 (1) 将所有的数据放在一张表内的弊端 表的组织结构不清晰 浪费存储时间 可扩展性极差 ---> 类似于将所有的代码写入到一个py文件中 -->解耦部分 (2) 如何 ...
- 【MySQL】数据库表操作
文章目录 1.创建和管理数据库 1.1 创建数据库 1.2 查看数据库 1.3 修改数据库 1.4 删除数据库 2. 创建表 2.1 创建表CREATE 2.2 创建表AS 2.3 查看表结构 3.修 ...
最新文章
- Eigen::Map
- How is note created - backend implementation
- 编写高性能 .NET 代码 第一章:工具介绍 -- Performance Counters(性能计数器)
- 《高性能MySQL》读书笔记-mysql数据类型和应用
- TextView IME option
- 服务器和硬盘如何区分,服务器硬盘和普通硬盘区别介绍
- 做软件也是要有点追求的
- 最快的滚屏截图软件--SpaceCapture
- c libxml2库的编译和使用
- 如何在word中一次性删除硬回车或软回车
- HDLBits—Exams/ece241 2014 q7a
- 史上最全!20/21届春招/秋招 实习/校招 JAVA面试全攻略!复习回顾这一篇就够了!
- (邀请函)澳大利亚堪培拉留学报告会面签会12月12号在北京理工大学举办
- H5编辑器H5-Dooring2.30更新指南
- 崩坏三 夏日竞猜 7.21 第一场
- 我理解的企业技术管理(三)——如何做好技术管理
- 数据结构实验报告:图的基本操作及应用
- 高并发下的缓存问题及布隆过滤器
- 线性筛求莫比乌斯函数前缀和
- 自学python有什么建议,想通过自学Python,朋友们有哪些提议吗?