数据库实验4

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验4 数据查询

1.实验目的

(1)掌握使用Transact-SQL的SELECT语句进行基本查询的方法。

(2)掌握使用SELECT语句进行条件查询的方法。

(3)掌握SELECT语句的GROUP BY、ORDER BY以及UNION子句的作用和使用方法。

(4)掌握嵌套查询的方法。

(5)掌握连接查询的操作方法。

2.实验内容及步骤

(1)在studentsdb数据库中,使用下列SQL语句将输出什么?

①SELECT COUNT(*) FROM grade

显示grade表中的数据条数

②SELECT SUBSTRING(姓名,1,2) FROM student_info

显示student_info表中姓名,1,2列对应的数据

③SELECT UPPER('kelly')

将'kelly'字符转换成大写

④SELECT Replicate('kelly',3)

将kelly字符复制三次

⑤SELECT SQRT(分数) FROM grade WHERE 分数>=85

显示grade 表中分数字段中大于等于85的数据平方根

⑥SELECT 2,3,POWER(2,3)

显示一条3项数据,分别为2,3,8

⑦SELECT YEAR(GETDA TE()),MONTH(GETDA TE()),DAY(GETDA TE())

(2)在studentsdb数据库中使用SELECT语句进行基本查询。

①在student_info表中,查询每个学生的学号、姓名、出生日期信息。

select学号,姓名,出生日期from student_info

②查询学号为0002 的学生的姓名和家庭住址。

select姓名,家庭住址from student_info where学号='0002'

③找出所有男同学的学号和姓名。

select学号,姓名from student_info where性别='男'

(3)使用SELECT语句进行条件查询。

①在grade表中查找分数在80~90范围内的学生的学号和分数。

select学号,分数from grade where分数between 80 and 90

②在grade表中查询课程编号为0003的学生的平均分。

select avg(分数)from grade where学号='0003'

③在grade表中查询学习各门课程的人数。

select count(*)from grade group by课程编号

④将学生按出生日期由大到小排序。

⑤查询所有姓“张”的学生的学号和姓名。

SELECT学号,姓名FROM student_info WHERE姓名LIKE'张%'

(4)对student_info表,按性别顺序列出学生的学号、姓名、性别、出生日期及家庭住址,性别相同的按学号由小到大排序。

select*from student_info order by出生日期desc

(5)使用GROUP BY查询子句列出各个学生的平均成绩。

(6)使用UNION运算符将student_info表中姓“张”的学生的学号、姓名与curriculum 表的课程编号、课程名称返回在一个表中,且列名为u_编号、u_名称,如图.1-8所示。

图1-8 联合查询结果集

(7)嵌套查询。

①在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。

SELECT姓名,出生日期

FROM student_info

WHERE性别=

(SELECT性别

FROM student_info

WHERE姓名='刘卫平')

②使用IN子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。

③列出学号为0001的学生的分数比0002号的学生的最低分数高的课程编号和分数。

④列出学号为0001的学生的分数比学号为0002的学生的最高成绩还要高的课程编号和分数。

(8)连接查询。

①查询分数在80~90范围内的学生的学号、姓名、分数。

SELECT student_info.学号,姓名,分数

FROM student_info,grade

WHERE student_info.学号=grade.学号 AND 分数 BETWEEN 80 AND 90

②查询学习“C语言程序设计”课程的学生的学号、姓名、分数。

③查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。

④查询每个学生的所选课程的最高成绩,要求列出学号、姓名、课程编号、分数。

⑤查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总

成绩为空。

使用左外连接。

⑥为grade表添加数据行:学号为0004、课程编号为0006、分数为76。查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。

使用右外连接。

3.实验思考

(1)查询所有没有选修课程的学生信息,返回结果包括学号、姓名、性别。

(2)在student_info表和grade表之间实现交叉连接。

(3)查询每个学生的所选课程的成绩,并列出学号生成分组汇总行(总成绩)和明细行(各课成绩)。

使用SELECT语句的COMPUTE选项。

(4)在查询语句中SELECT、FROM和WHERE选项分别实现什么运算?

(5)在查询的FROM子句中实现表与表之间的连接有哪几种方式?对应的关键字分别是什么?

相关文档
最新文档