- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
第6章数据的高级操作
第6章数据的高级操作6.1连接查询6.2子查询6.3案例应用举例
6.1连接查询交叉连接查询等值与非等值连接查询自身连接查询外连接查询复合连接条件查询
交叉连接查询1.交叉连接的连接过程(交叉连接又称非限制连接,将两个表不加约束的连接在一起,产生的结果集的记录为两个表中记录的交叉乘积)例如,有一个学生1表和一个单科成绩表,如表6.1、表6.2所示,两个表交叉连接后产生的结果如表6.3所示,结果集是两个表记录的交叉乘积,列是两个表列的集合。①②③学号11杨文生12唐国栋14梁明亮学号成绩118013981576姓名表6.1表6.2
杨文生表6.3学号姓名学号成国栋118014梁明亮118011杨文生139812唐国栋139814梁明亮139811杨文生157612唐国栋157614梁明亮1576交叉连接查询
SELECT列名列表FROM表名1CROSSJOIN表名2交叉连接的语法格式如下:01USESTUDENTGOSELECT*FROM学生1CROSSJOIN单科成绩交叉查询学生1表和单科成绩表,代码如下:02交叉连接查询
等值与非等值连接查询例6.1:用等值连接的方法连接学生1表和单科成绩表代码如下:usestudentgoselect*from学生innerjoin单科成绩on学生1.学号=单科成绩.学号go用来连接两个表的条件称为连接条件,连接条件一般格式为:[表名1.]列名比较运算符[表名2.]列名而比较运算符为“=”时,称为等值连接,其他运算符的连接为非等值连接等值连接的语法格式:Select列名列表From表名1[inner]join表名2On表名1.列名=表名2.列名
例6.2:自然连接学生1表和单科成绩表。代码如下:usestudentgoselect学生1.学号,姓名,成绩from学生join单科成绩on学生1.学号=单科成绩.在等值连接中,把目标列中重复的属性列去掉则为自然连接等值与非等值连接查询
等值与非等值连接查询为了简便,在查询语句时可以使用表的别名,分配别名时,可以使用as关键字,也可以不使用。格式如下:数据表名as表别名数据表名表别名【6.4】使用表别名自然连接“学生1”表和“单科成绩”表。UsestudentGoSelects.学号,姓名,成绩from学生assinnerjoin单科成绩ascons.学号=c.学号go
一个表的两个副本之间的连接称为自身连接查询。1使用条件:当需要同时考查一个表中的多行(两行及以上)时2例6.3:查询选修了两门或两门以上课程的学生的学号和课程号。代码如下:3USEstudent4GO5SELECTDISTINCTa.学号,a.课程号6FROM课程注册ASaJOIN课程注册ASb7ONa.学号=b.学号ANDa.课程号!=b.课程号8GO9自身连接查询
外连接查询外连接有分为左外连接、右外连接、全外连接三种。外连接除产生内连接生成的结果集外,还可以使一个表(左、右外连接)或两个表(全外连接)中的不满足连接条件的记录也出现在结果集中。
外连接查询1.左外连接左外连接就是将左表作为主表,主表中所有记录分别与右表的每一条记录进行连接,结果集中除了满足连接条件的记录外,还有主表中不满足连接条件的记录,在右表的相应列上自动填充null值。格式如下:Select列名列表From表名1left[outer]join表名2on表名1.列名=表名2.列名例6.4:将学生1表左外连接单科成绩表。代码如下:USESTUDENTGOSELECT*FROM学生1LEFTOUTERJOIN单科成绩ON学生1.学号=单科成绩.学号
外连接查询2.右外连接右外连接就是将右表作为主表,主表中所有记录分别与左表的每一条记录进行连接,结果集中除了满足连接条件的记录外,还有主表中不满足连接条件的记录,在左表的相应列上自动填充null值。格式如下:Select列名列表From表名1right[outer]join表名2on表名1.列名=表名2.列名例6.5:将学生1表右外连接单科成绩表。代码如下:USESTUDENTGOSELECT*FROM学生1RIGHTOUTERJOIN单科成绩ON学生1.学号=单科成绩.学号GO
外连
文档评论(0)