您的位置:首页 > 文旅 > 旅游 > 110建筑人才网官网_网页上的视频怎么下载到电脑_中国第一营销网_百度收录查询代码

110建筑人才网官网_网页上的视频怎么下载到电脑_中国第一营销网_百度收录查询代码

2025/4/20 23:05:45 来源:https://blog.csdn.net/m0_74830524/article/details/143332886  浏览:    关键词:110建筑人才网官网_网页上的视频怎么下载到电脑_中国第一营销网_百度收录查询代码
110建筑人才网官网_网页上的视频怎么下载到电脑_中国第一营销网_百度收录查询代码

内连接和外连接

​ 表的连接分为内连接和外连接,内连接就是将需要连接的表形成笛卡尔积筛选;外连接分为左外连接和右外连接,左外连接为左侧的表需要完全显示,右外连接为右侧的表现需要完全显示。

文章目录

    • 内连接和外连接
      • 内连接
      • 外连接
        • 左外连接
        • 右外连接

内连接

​ 内连接实际上就是使用where子句对两种表形成的笛卡尔积进行筛选,前面文章(MySql中表的复合查询-CSDN博客)中介绍的查询都是内连接查询,在实际开发项目中用得最多的也是内连接查询。

​ 语法:

select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

​ 显示SMITH的名字和部门名称,如下:

mysql> select ename, dname from emp, dept where emp.deptno = dept.deptno and ename = 'SMITH';
+-------+----------+
| ename | dname    |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+
1 row in set (0.00 sec)-- 使用标准的内连接写法
mysql> select ename, dname from emp inner join dept on dept.deptno = emp.deptno and ename = 'SMITH';
+-------+----------+
| ename | dname    |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+
1 row in set (0.00 sec)

外连接

​ 外连接分为左外连接和右外连接

左外连接

​ 在联合查询中,左侧的表完全显示就为左外连接。

​ 语法:

select 字段名 from 表名1 left join 表名2 on 连接条件;

​ 案例如下:
在这里插入图片描述

​ 如上所示创建的两张表。

​ 查询所有学的成绩,若这个学生没有成绩,也要将该学生的个人信息显示出来,如下:

mysql> select stu.id, name, grade from stu left join exam on exam.id = stu.id;
+------+------+-------+
| id   | name | grade |
+------+------+-------+
|    1 | jack |    56 |
|    2 | tom  |    76 |
|    3 | kity |  NULL |
|    4 | nono |  NULL |
+------+------+-------+
4 rows in set (0.00 sec)
右外连接

​ 联合查询中,右侧的表完全显示就是右外连接。

​ 语法:

select 字段 from 表名1 right join 表名2 on 连接条件;

​ 对stu和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与其对应,也要显示,如下:

mysql> select stu.id, name, grade from stu right join exam on exam.id = stu.id;
+------+------+-------+
| id   | name | grade |
+------+------+-------+
|    1 | jack |    56 |
|    2 | tom  |    76 |
| NULL | NULL |     8 |
+------+------+-------+
3 rows in set (0.00 sec)

​ 列出部门名称和这些部门的员工信息,同时列出没有员工的部门,如下:

select dname, emp.* from dept left join emp on dept.deptno = emp.deptno;select dname, emp.* from emp right join dept on dept.deptno = emp.deptno;

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com