③ 查询平均成绩在80分以上的各位学生的学号、姓名和平均分。保存为查询对象,对象名“优秀学生”。
单击工具栏保存按钮,弹出“另存为”对话框,输入“优秀学生”,单击“确定”按钮。
④ 查询没有学生数据的专业编号和专业。
⑤ 查询“湖北”籍1988年以后出生的学生信息。
⑥ 查询选课人数最多的课程的课程号、课程名。
2.练习SQL的插入、更新、删除操作命令
① 在课程表中插入一门新课,数据如命令所示。
② 将“法学院(04)”开设课程的学分增加1分。
③ 删除“信息学院(09)”开设的没有学生选修的课程。
3.创建“教师”表,包括:工号、姓名、性别、生日、职称、基本工资、学院号。写出创建命令。
create table 教师
(工号 text(6) primary key, 姓名 text(10) not null, 性别 text(2), 生日 date, 职称 text(8), 基本工资 money,
学院号 text(2) references 学院(学院号))
(三)选择查询操作
1.进入查询设计视图进行交互式选择查询设置 启动教学管理数据库。
① 查询“专业”表,显示开设的所有专业涉及的学科门类。
将“专业”表加入设计视图。在QBE界面中“字段”栏选择“专业类别”字段显示。因该字段的值有重复,因此,在设计视图的空白处单击右键,从弹出的快捷菜单中选择“属性”命令,打开“属性”对话框,选择“唯一值”属性值“是”。
② 查询各专业学生的人数。
将“专业”表和“学生”表加入设计视图。在QBE界面中“字段”栏选中“专业号”和“专业”字段显示,然后单击工具栏中“总计”按钮,在QBE中增加“总计”栏。将“专业号”和“专业”字段设置为“分组”,然后选择“学生”表的“学号”字段,设置其为“计数”,最后在学号前面加上“人数”,作为查询后的列名。
③ 查询没有选课的男学生学号、姓名,即成绩表中没有记录的学生数据。
将“学生”表加入设计视图。选择“学号”、“姓名”字段显示,在第三列处输入“注:‘尚未选课’”,选中“显示”复选框。然后在第四列中选择“学号”但不显示,只是作为比较的对象。在“条件”栏中输入一个子查询“not in ((select 学号 from 成绩)”。
2.进行交叉表查询
将学生的“学号”和“姓名”作为行标题,“课程名”作为列标题,成绩作为交叉数据,生成交叉表。
启动选择查询设计窗口,将“学生”、“成绩”和“课程”表加入设计窗口。选择“查询”——“交叉表查询”命令。在QBE窗格中选择“学生”表的“学号”、“姓名”作为行标题,“课程名”