资源描述:
《数据库原理与应用 数据库查询操作》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、《数据库原理与应用》实验报告题目:实验四:数据库查询操作学号:1148028姓名:沈宇杰日期:2013/4/27实验预习情况:实验目的:①:掌握两种方式的数据查询方法②:掌握简单查询、连接查询、嵌套查询等。查询工具的选择:①:对于简单的查询,更适合使用SQLServerManagementStudio工具进行查询。②:对于复杂的查询,更适合使用SQL语句进行查询。预习报告:使用SQLServerManagementStudio工具进行查询①:查询数据表的全部数据在对象资源管理器中,右击需要查询的表,选择
2、编辑前两百行,此时就显示了Student表中的全部数据了。②:使用SELECT语句查询数据表的数据在对象资源管理器中,右击需要查询的表,选择编辑前两百行命令,单击工具栏上的“显示SQL窗口”,此时子窗口将分为上下两部分,上面的部分可以输入SQL语句,下面的窗口会列出查询的结果。例如:查询Student表中所有的信息。可以使用SQL语句为:SELECTTOP(200)Sno,Sname,Ssex,Sage,SdeptFROMStudent③:学习和使用QBE查询在对象资源管理器中,右击需要查询的表,选择编
3、辑前两百行命令,选择QBE查询条件,执行时单击工具栏上的“执行”按钮。若单击工具按按钮“显示/隐藏SQL窗口”,则会在SQL窗格中自动生成对应的SQL语句。例:使用QBE查询数据表Student中大于等于20岁的女生的性别和年龄。直接在输出列表中选择要显示的属性名即可,在SQL窗口中会自动生成相关的SQL代码④:实现多表查询在对象资源管理器中,右击需要操作的数据表,选择“编辑前两百行”命令,单击工具栏上的“显示/隐藏关系图窗格”,然后,单击工具栏按钮“添加表”,即可将数据表添加到关系图窗格中,单击字段左
4、边的复选框选择要输出的数据列,执行时单击工具栏按钮“运行”即可。例:利用资源对象管理器查询所有男生的学生成绩,输出列包括:学号、姓名、课程号和成绩。自动生成的SQL代码为:SELECTTOP(200)Student.Sno,Student.Sname,Student.Sdept,SC.Grade,Course.CnameFROMStudentINNERJOINSCONStudent.Sno=SC.SnoINNERJOINCourseONSC.Cno=Course.Cno使用SQL语句进行查询简单查询:选
5、择列:1.用SELECT语句来指定查询所需的列,多个列之间用“,”隔开例如:查询Student表中所有学生的学号、姓名、性别。SELECTSno学号,Sname姓名,Ssex性别FROMStudent2.使用“*”来选取数据表的全部列例如:查询Student表中所有学生的基本情况。SELECT*FROMStudent3.在查询结果中增加计算列,还可以修改数据列的显示名称例如:查询Student表中所有学生的学号、姓名、性别、和出生年份。SELECTSno学号,Sname姓名,Ssex性别,YEAR(Ge
6、tDate())-Sage出生年份FROMStudent选择行:1.使用WHERE子句,可以选择满足条件的部分记录例如:查询成绩在85~90分之间的学生情况SELECTSno,Cno,GradeFROMSCWHEREGrade>=85ANDGrade<=902.使用DISTINCT关键字,可以消除重复记录例如:查询有成绩的学生的学号。SELECTDISTINCTSnoFROMSC3.使用IN关键字,选择不连续条件的记录例如:查询学生成绩为80或85的学生的学号USEmydbGOSELECT*FROMSC
7、WHEREGradeIN(80,85)4.使用谓词LIKE和通配符“%”或“—”,实现模糊查询。例如:查询姓“张”的学生的基本情况。SELECT*FROMStudentWHERESnameLIKE'张%'注意:这里的“%”代表0或多个字符,“—”代表一个字符,有的书上说,一个汉字占用两个字符,但这里的汉字只占一个字符位置,这与系统的设置有关。对查询结果排序1.使用ORDERBY子句,对查询结果进行排序例如:查询所有学生的2号课的成绩,并按成绩又高向低排序。SELECT*FROMSCWHERECno=2O
8、RDERBYGradeDESC2.使用TOP关键字,选择查询结果的前几条记录例如:查询2号课成绩最高的学生记录SELECTTOP1*FROMSCWHERECno=2ORDERBYGradeDESC注意:TOP1的意思是查询前一个数据,TOP2就是查询前两个数据,这两句命令并非是查询第一个数据或查询第二个数据的意思。对查询结果进行分组1.使用GROUPBY子句,对查询结果进行分组例如:查询各门课及相应的选课人数。SELECTCno课程号,CO