资源描述:
《SQL语句——SELECT查询操作.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实验报告【实验名称】SQL语言——SELECT查询操作姓名:学号:班级:日期:10月26日【实验目的】1.掌握SQL程序设计基本规范,熟练运用SQL语言实现数据基本查询,包括单表查询、分组统计查询和连接查询。2.掌握SQL嵌套查询和集合查询等各种高级查询的设计方法等。【实验环境】SQLSERVER2008【实验内容】1.针对SQLServer数据库设计各种单表查询语句、分组统计查询语句;设计单个表针对自身的连接查询,设计多个表的连接查询。理解和掌握SQL查询语句各个子句的特点和作用,按照SQL程序设计规范写出具体的SQ
2、L查询语句,并调试通过。2.针对SQLServer数据库,正确分析用户查询要求,设计各种嵌套查询和集合查询。【实验代码】--在选课系统下进行以下查询--单表查询SELECT*FROMStudentSELECTSname,2014-SageFROMStudentSELECTSname,'YearofBirth:',2014-Sage,LOWER(Sdept)FROMStudentSELECTSnameNAME,'YearofBirth:'BIRTH,2014-SageBIRTHDAY,LOWER(Sdept)DEPART
3、MENT--改变查询结果的列标题FROMStudentSELECTDISTINCTSno--去掉结果表中的重复行FROMSCSELECTSname,Sdept,SageFROMStudentWHERESdeptIN('CS','MA','IS')--确定集合SELECT*FROMStudentWHERESnoLIKE'201215121'--字符匹配SELECTSname,Sno,SsexFROMStudentWHERESnameLIKE'刘%'SELECTSnameFROMStudentWHERESnameLIKE'
4、李_'SELECTSno,CnoFROMSCWHEREGradeISNOTNULLSELECTSno,GradeFROMSCWHERECno='3'ORDERBYGradeDESCSELECTCOUNT(*)FROMStudentSELECTSnoFROMSCGROUPBYSnoHAVINGCOUNT(*)>1--等值与非等值连接查询SELECTStudent.Sno,SnameFROMStudent,SCWHEREStudent.Sno=SC.SnoANDSC.Cno='2'ANDSC.Grade>90--自身连接S
5、ELECTFIRST.Cno,SECOND.CpnoFROMCourseFIRST,CourseSECONDWHEREFIRST.Cpno=SECOND.Cno--外连接SELECTStudent.Sno,Sname,Ssex,Sage,Sdept,Cno,GradeFROMStudentLEFTOUTERJOINSCON(Student.Sno=SC.Sno)--多表连接SELECTStudent.Sno,Sname,Cname,GradeFROMStudent,SC,CourseWHEREStudent.Sno=S
6、C.SnoANDSC.Cno=Course.Cno--嵌套查询SELECTSname,SageFROMStudentWHERESage'CS'--集合查询SELECTSnoFROMSCWHERECno='1'UNIONSELECTSnoFROMSCWHERECno='2'--基于派生表的查询SELECTSnameFROMStudent,(SELECTSnoFROMSCWHERECno='1')ASSC1WHERESt
7、udent.Sno=SC1.Sno【查询结果】【实验心得】数据查询是数据库的核心操作。SQL提供了SELECT语句进行数据查询,SELECT语句既可以完成简单的单表查询,也可以完成复杂的连接查询和嵌套查询,方法功能多样。实验的语句基本来自于课本例题,通过实地的上机操作,对于这些查询方式的理解有了很大的提高,虽然让自己写出来仍然存在一些困难,但是这些语句已经较为地熟悉,相信经过多加练习,就可以根据用户的具体查询要求设计出合理正确的查询语句。单表查询比较简单,连接查询、嵌套查询相对较为复杂,而且形式也较为多样,部分情况下,
8、连接查询可以和嵌套查询相替换,可以根据实际问题决定使用哪一个,在这些查询上还需要多下功夫。