前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL | 表的内连接

MySQL | 表的内连接

作者头像
Zkeq
发布2022-05-18 15:36:29
3.3K0
发布2022-05-18 15:36:29
举报
文章被收录于专栏:Zkeq

数据操作语言:表连接查询(一)

从多张表中提取数据

  • 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积
1
1
  • 规定了连接条件的表连接语句,就不会出现笛卡尔积。
2
2
代码语言:javascript
复制
# 查询每名员工的部门信息
SELECT e.empno,e.ename,d.dname
FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno;

表连接的分类

  • 表连接分为两种:内连接 和 外连接
  • 内连接是结果集中只保留符合连接条件的记录
  • 外连接是不管符不符合连接条件,记录都要保留在结果集

内连接的简介

  • 内连接是最常见的一种表连接,用于查询多张关系表符合连接条件的记录。
3
3

内连接的多种语法形式

代码语言:javascript
复制
SELECT ...... FROM 表1 JOIN 表2 ON 连接条件;
代码语言:javascript
复制
SELECT ...... FROM 表1 JOIN 表2 WHERE 连接条件;
代码语言:javascript
复制
SELECT ...... FROM 表1, 表2 WHERE 连接条件;

4
4
代码语言:javascript
复制
# 查询每名员工的部门信息
SELECT e.empno,e.ename,d.dname
FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno;

SELECT e.empno,e.ename,d.dname
FROM t_emp e JOIN t_dept d WHERE e.deptno=d.deptno;

SELECT e.empno,e.ename,d.dname
FROM t_emp e , t_dept d WHERE e.deptno=d.deptno;

内连接练习1
  • 查询每个员工的 工号、姓名、部门名称、底薪、职位、工资等级?
代码语言:javascript
复制
# 查询每个员工的 工号、姓名、部门名称、底薪、职位、工资等级?
SELECT e.empno,e.ename,d.dname,e.sal,e.job,s.grade
FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno
JOIN t_salgrade s ON e.sal BETWEEN s.losal AND s.hisal;

  • 内连接的数据表不一定必须有同名字段,只要字段之间符合逻辑关系就可以
内连接练习2
  • 查询与 SCOTT 相同部门的员工都有谁?
代码语言:javascript
复制
# 查询与 SCOTT 相同部门的员工都有谁?
SELECT ename
FROM t_emp
WHERE deptno=(SELECT deptno FROM t_emp WHERE ename="SCOTT")
AND ename!="SCOTT";

代码语言:javascript
复制
# 查询与 SCOTT 相同部门的员工都有谁?

SELECT e2.ename
FROM t_emp e1 JOIN t_emp e2 ON e1.deptno=e2.deptno
WHERE e1.ename="SCOTT" AND e2.ename!="SCOTT";

  • 相同的数据表也可以做表连接
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 从多张表中提取数据
  • 表连接的分类
  • 内连接的简介
  • 内连接的多种语法形式
    • 内连接练习1
      • 内连接练习2
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档