企业首次建设网站的策划方案,阿里国际网站做免费有用吗,网站怎么做值班表,大岭山网站建设文章目录 MySQL内外连接1.内连接2.外连接#xff08;1#xff09;左外连接#xff08;2)右外连接 3.简单案例 MySQL内外连接
1.内连接
内连接的SQL如下#xff1a;
SELECT ... FROM t1 INNER JOIN t2 ON 连接条件 [INNER JOIN t3 ON 连接条件] ... AND 其他条件;说明一下… 文章目录 MySQL内外连接1.内连接2.外连接1左外连接2)右外连接 3.简单案例 MySQL内外连接
1.内连接
内连接的SQL如下
SELECT ... FROM t1 INNER JOIN t2 ON 连接条件 [INNER JOIN t3 ON 连接条件] ... AND 其他条件;说明一下
SQL中大写的表示关键字[ ]中代表的是可选项。内连接的条件通过连接条件指明用户的其他筛选条件通过其他条件指明。 显示SMITH的名字和部门名称 给出一张员工表和一张部门表员工表中的ename代表的是员工的姓名deptno代表的是员工所在部门的部门号。如下 部门表中的dname代表的是部门名deptno代表的是部门的部门号。如下 现在要显示SMITH的名字和其所在部门的名称按照复合查询的做法就是取员工表和部门表的笛卡尔积在where子句中指明筛选条件为员工的部门号等于部门的部门号筛选出每个员工匹配的部门信息并指明员工姓名为SMITH筛选出SMITH的信息和其所在部门的信息。如下 实际上述多表查询的方式本质就是内连接用标准的内连接SQL编写
将员工表和部门号放在from子句中并通过inner join关键字隔开。在on子句后指明内连接的条件为员工的部门号等于部门的部门号保证筛选出来的数据是有意义的。在and之后指明筛选条件为员工的姓名为SMITH。
这样筛选出来的结果和多表查询筛选出来的结果是一样的只不过是写法有一点不同而已。如下 2.外连接
外连接分为左外连接和右外连接。
1左外连接
左外连接的SQL如下
SELECT ... FROM t1 LEFT JOIN t2 ON 连接条件 [LEFT JOIN t3 ON 连接条件] ... AND 其他条件;说明一下
SQL中大写的表示关键字[ ]中代表的是可选项。左外连接的条件通过连接条件指明用户的其他筛选条件通过其他条件指明。 查询所有学生的成绩就算这个学生没有成绩也要将学生的个人信息显示出来 给出一张学生表和一张成绩表学生表中的name代表的是学生的姓名id代表的是学生的学号。如下 成绩表中的id代表的是考试学生的学号score代表的是学生的成绩。如下 现在要显示所有学生的成绩如果直接使用内连接将学生表和成绩表连接起来然后筛选出学生学号等于考试学生学号的记录那么只能筛选出有考试成绩的学生信息。如下 而题目要求将没有成绩的学生的个人信息也要显示出来也就是学生表当中的内容需要完全被显示出来。如果在连接学生表和成绩表时将学生表放在左侧那么就可以使用左外连接这时如果左侧表中的某条记录根据连接条件没有找到匹配的右侧表中的记录就会直接显示左侧表中的记录信息而其对应的右侧表中的列信息将会用NULL值进行填充。如下 2)右外连接
右外连接的SQL如下
SELECT ... FROM t1 RIGHT JOIN t2 ON 连接条件 [RIGHT JOIN t3 ON 连接条件] ... AND 其他条件;说明一下
SQL中大写的表示关键字[ ]中代表的是可选项。右外连接的条件通过连接条件指明用户的其他筛选条件通过其他条件指明。 查询所有的成绩就算这个成绩没有学生与它对应也要将成绩信息显示出来 题目要求将没有学生与它对应的成绩信息也要显示出来也就是成绩表当中的内容需要完全被显示出来。如果在连接学生表和成绩表时将成绩表放在右侧那么就可以使用右外连接这时如果右侧表中的某条记录根据连接条件没有找到匹配的左侧表中的记录就会直接显示右侧表中的记录信息而其对应的左侧表中的信息将会用NULL值进行填充。如下 3.简单案例 列出部门名称和这些部门的员工信息同时列出没有员工的部门 由于题目要求同时列出部门名和员工信息因此需要将部门表和员工表连接起来连接条件就是部门的部门号要等于员工所在的部门号。如果直接使用内连接进行查询那么将会显示出所有满足连接条件的记录。如下 而题目要求同时列出没有员工的部门也就是部门表当中的内容需要完全被显示出来如果在连接部门表和员工表时将部门表放在左侧那么就可以使用左外连接。如下 当然如果要使用右外连接那么可以在连接部门表和员工表时将部门表放在右侧。如下 本文到此结束码文不易还请多多支持哦