- 1、本文档共67页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
ch06_数据查询
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 例30:删除计算机科学系所有学生的选课记录 四、更新数据 格式 UPDATE 表名 SET 列名=表达式[,列名=表达式]... [WHERE 条件]; 例31:将学生95001的年龄改为22岁 例32:将所有学生的年龄增加1岁 例33:将计算机科学系全体学生的成绩置0 * * * * * * * * * * * * * * SELECT Sno, Sname, Year(Now) - Sage AS 出生年份 FROM Student * * * * * * * * * * * * * 多重条件查询 使用逻辑运算符AND和OR来联结多个查询条件。AND的优先级高于OR。 例15:查询CS系年龄在22岁以下的学生姓名。 如果没有指定查询结果的显示顺序,DBMS将按其最方便的顺序(通常是元组在数据表中的先后顺序)输出查询结果。 用户也可以用ORDER BY子句指定按照一个或多个属性列的升序(ASC)或降序(DESC)重新排列查询结果,其中升序ASC为缺省值。 结果排序 例16:查询选修了3号课程的学生的学号及其成绩,查询结果按分数的降序排列。 例17:查询全体学生情况,查询结果按所在系升序排列,对同一系中的学生按年龄降序排列。 SQL提供了许多集函数,主要包括:COUNT、SUM、AVG、MAX、MIN 统计函数 例18:查询学生总人数 例19:查询选修了课程的学生人数 SELECT COUNT(Sno) AS 人数 FROM SC 注:在Access中,AS不能省略! SELECT COUNT (Sno) AS 人数 FROM (SELECT DISTINCT Sno FROM SC) 注:在Access中,不能使用COUNT(Distinct Sno) 例20:计算2号课程的学生平均成绩 SELECT AVG(Grade) as AvgGrade FROM SC WHERE Cno = 2 例21:查询学习2号课程的学生最高分数 SELECT MAX(Grade) AS MaxGrade FROM SC WHERE Cno = 2 GROUP BY子句可以将查询结果表的各行按一列或多列值分组,值相等的为一组。 对查询结果分组的目的是为了细化集函数的作用对象。如果未对查询结果分组,集函数将作用于整个查询结果,即整个查询结果只有一个函数值。否则,集函数将作用于每一个组,即每一组都有一个函数值。 结果分组 例22:查询各个课程号与相应的选课人数 SELECT Cno, COUNT(Sno) AS 人数 FROM SC GROUP BY Cno 例23:查询选修了2门以上课程的学生的学号 先用GROUP BY子句按Sno分组,再用集函数COUNT对每一组计数。HAVING短语指定选择组的条件,只有满足条件(即元组个数2,表示此学生选修的课超过2门)的组才会被选出来。 WHERE子句与HAVING短语的区别在于作用对象不同。WHERE子句作用于基本表或视图,从中选择满足条件的元组。HAVING短语作用于组,从中选择满足条件的组。 * 若一个查询同时涉及两个以上的表,则称之为连接查询。 等值、非等值连接查询 自身连接查询 外连接查询 复合条件连接查询 2 连接查询 * 当连接运算符为“=”时,称为等值连接,否则称为非等值连接。 一、等值、非等值连接 * 例29:查询每个学生及其选修课程的情况 * * 例30:自然连接Student和SC表 注1:在等值连接中去掉重复的属性列,即为自然连接。 注2:若属性列在两个表中是唯一的,可以省略表名前缀。 * * 例31:查询每一门课的间接先修课(即先修课的先修课) 二、自身连接 * * 在通常的连接操作中,只有满足连接条件的元组才能作为结果输出,如在例29和例30的结果表中没有关于95003和95004两个学生的信息,原因在于他们没有选课,在SC表中没有相应的元组。 有时我们想以Student表为主体列出每个学生的基本情况及其选课情况,若某个学生没有选课,则只输出其基本情况信息,其选课信息为空值即可,这时就需要使用外连接(Outer Join)。外连接的运算符不同的DBMS实现的方式不一样。在SQL Server中采用了LEFT JOIN或RIGHT JOIN短语。 三、外连接 * 例32:查询每个学生及其选修课程的情况(即使没有选课也列出该学生的基本情况) * 上面各个连接查询中,WHERE子句中只有一个条件,即用于连接两个表的谓词。WHERE子句中有多个条件的连接操作,称为复合条件连接。 例
您可能关注的文档
- 2013年进销存软件排名.docx
- CSV文件处理算法.docx
- BCP 工具使用.doc
- MSSQL数据导入导出.doc
- Sybase IQ之导出、导入研究.docx
- sybase_iq数据库迁移实例.doc
- SQL SERVER 与ACCESS.docx
- sybase导数宝典.doc
- 创智_DRMS_解决方案_数据通讯 20131224.pdf
- 将Excel2007表格批量导入SQL Server2005.docx
- [中央]2023年中国电子学会招聘应届生笔试历年参考题库附带答案详解.docx
- [吉安]2023年江西吉安市青原区总工会招聘协理员笔试历年参考题库附带答案详解.docx
- [中央]中华预防医学会科普信息部工作人员招聘笔试历年参考题库附带答案详解.docx
- [保定]河北保定市第二医院招聘工作人员49人笔试历年参考题库附带答案详解.docx
- [南通]江苏南通市崇川区人民法院招聘专职人民调解员10人笔试历年参考题库附带答案详解.docx
- [厦门]2023年福建厦门市机关事务管理局非在编工作人员招聘笔试历年参考题库附带答案详解.docx
- [三明]2023年福建三明市尤溪县招聘小学幼儿园新任教师79人笔试历年参考题库附带答案详解.docx
- [哈尔滨]2023年黑龙江哈尔滨市木兰县调配事业单位工作人员笔试历年参考题库附带答案详解.docx
- [上海]2023年上海市气象局所属事业单位招聘笔试历年参考题库附带答案详解.docx
- [台州]2023年浙江台州椒江区招聘中小学教师40人笔试历年参考题库附带答案详解.docx
文档评论(0)