求SQL2000高级查询里,左连接用where语句的语法。

求SQL2000高级查询里,左连接用where语句的语法。,第1张

正好我也复习到这块知识点 发现书上编的有问题

搜了一下 找到答案了

举个例子说明下..

【例】查询“学生信息”表中全部学生的学号、姓名和在“学生成绩”表中的课程号和期末成绩,将学生信息表定义为主表,学生成绩表为从表进行左连接。

方法一: 使用where子句

Select 学生信息.学号,学生信息.姓名,学生成绩.课程号,学生成绩.期末成绩

From 学生信息,学生成绩

Where 学生信息.学号*=学生成绩.学号

(注:也就是在=的左侧添加一个*)

方法二: 使用left join语法

Select 学生信息.学号,学生信息.姓名,学生成绩.课程号,学生成绩.期末成绩

From 学生信息 left outer join 学生成绩

On 学生信息.学号=学生成绩.学号

希望你能满意^_^

1、首先在电脑中打开sql,在外层查询中写上S【elect * From S】查询出学生信息,如下图所示。

2、然后,再以同样的方法找出SC选修表,如下图所示。

3、此时,就可以在这里利用等值连接将S和SC表连接,如下图所示。

4、但是,因为这是不同层级的查询,因此需要Exists谓词将他们连接。

5、运行后,就可以看到这样的结果,如下图所示就完成了。

SQL中左连接和右连接都属于外连接。

左连接是LEFT  JOIN或LEFT OUTER JOIN,左向外联接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。  

右连接是RIGHT  JOIN 或 RIGHT  OUTER  JOIN,右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

举例:要查询所有学生的选课情况,包括已经选课的和还没有选课的学生,查询语句为SELECT学生表.学号,姓名,班级,课程号,成绩 FROM学生表LEFT OUTER JOIN选课表ON学生表.学号=选课表.学号,左外连接查询中左端表中的所有元组的信息都得到了保留。

扩展资料

连接查询是关系数据库中最主要的查询,主要包括内连接、外连接和交叉连接等。联接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定联接条件。WHERE和HAVING子句也可以包含搜索条件,以进一步筛选联接条件所选的行。  

内连接是INNERJOIN简写成JOIN,是典型的联接运算,使用像 =  或 <>之类的比较运算符。包括相等联接和自然联接。内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如,检索 students和courses表中学生标识号相同的所有行。

外联接除了左右连接外,还有完整外部联接FULL  JOIN 或 FULL OUTER JOIN,完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接也称作笛卡尔积。FROM 子句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,用左或右向外联接指定表或视图时,表或视图的顺序很重要。

参考资料 百度百科-连接查询


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10873397.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-11
下一篇 2023-05-11

发表评论

登录后才能评论

评论列表(0条)

保存