标用于定位结果集的行,通过判断全局变量@@FETCH_STATUS可以判断是否到了最后,通常此变量不等于0表示出错或到了最后。
数据库笔试题4: 触发器分为事前触发和事后触发,这两种触发有和区别。语句级触发和行级触发有何区别。
事前触发器运行于触发事件发生之前,而事后触发器运行于触发事件发生之后。通常事前触发器可以获取事件之前和新的字段值。
语句级触发器可以在语句执行前或后执行,而行级触发在触发器所影响的每一行触发一次。
现有数据库结构及数据如下:
学生表(students)
st_id st_name(姓名) sex(性别)
st001 张杰 男
st002 公孙燕飞 男
st003 王楠 女
st004 王伟 男
st005 李燕纹 女
st006 孙武 男
老师表(teachers)
t_id(主键,编号) t_name(姓名) t_lesson(课程)
t001 张老师 数学
t002 李老师 英语
成绩表(results)
r_id r_fenshu(int) r_stid r_tid
r001 90 st001 t002
r002 68 st005 t001
r003 92 st003 t001
r004 82 st006 t002
r005 70 st002 t002
r006 86 st002 t001
r007 57 st003 t002
r008 76 st006 t001
r009 55 st001 t001
r010 77 st004 t002
r011 58 st005 t002
以上数据库结构中字段未标明具体类型的,皆为varchar类型。
基础题:
1)查询出王伟同学的学生编号。
2)查询出名子第三个字是“燕”字的学生的编号和姓名。
3)查询显示出所有男学生的姓名及其名子的长度。
4)查出数学考试成绩的最低分。
5)查出所有女学生的各科成绩。
6)查出英语考试成绩的平均分。
7)在全部男学生中查询出学生编号最后两名的所有信息,并以学生编号降序显示。
8)统计出王楠同学在这次考试中的所有课程成绩的合计分。
9)查询所有课程考试中成绩及格,但未达到90分的学生的姓名。(不显示重复姓名)
10)给所有女学生的考试成绩每科加10分。
进阶题:
1)统计出数学考试的及格人数,并显示出授课老师的姓名。
2)按课程统计查询出总分合计最多的课程,显示出该课程的名称、总分、授课老师的编号及姓名。
3)在这次的考试中有一个学生缺考了一门课程,根据学校规定,缺考任何一门课程,该学生的其它课程考试成绩也视同无效,故请用一条SQL语句删除掉此次缺考学生的其它课程考试成绩。
选作题:
1)列出数据库里所有的用户表名称。
2)使用一条SQL语句随机从学生表中取出5个学生的信息。
高悬赏分求其中的几题的答案!!!!!!!!!!
问题补充:谢谢各位大人,这么多人答出来了,是否要我考虑下,怎么送分,大家平均下可以吗 我不晓得有没有这个功能#35,我先找找看,假如不行,我就给第一个答出我全部题目的,大家有意见吗
参考答案:
create table students(st_id varchar(20),st_name varchar(50),sex varchar(10))
insert into students(st_id,st_name,sex)
select ‘st001′,’张杰’, ‘男’ union all
select ‘st002′, ‘公孙燕飞’ ,’男’ union all
select ‘st003′, ‘王楠’, ‘女’ union all
select ‘st004′, ‘王伟’, ‘男’ union all
select ‘st005′,’李燕纹’, ‘女’ union all
select ‘st006′, ‘孙武’ ,’男’
select *
from students
create table teachers(t_id varchar(20),t_name varchar(50),t_lesson varchar(50))
insert into teachers
select ‘t001′, ‘张老师’ ,’数学’ union all
select ‘t002′, ‘李老师’, ‘英语’
delete from results
create table results(r_id varchar(20),r_fenshu int,r_stid varchar(50),r_tid varchar(50))
insert into results
select ‘r001′,’90′, ‘st001′, ‘t002′ union all
select ‘r002′, ’68′, ‘st005′, ‘t001′ union all
select ‘r003′, ’92′, ‘st003′ ,’t001′ union all
select ‘r004′, ’82′, ‘st006′, ‘t002′ union all
select ‘r005′, ’70′, ‘st002′, ‘t002′ union all
select ‘r006′, ’86′, ‘st002′, ‘t001′ union all
select ‘r007′, ’57′, ‘st003′, ‘t002′ union all
select ‘r008′, ’76′, ‘st006′, ‘t001′ union all
select ‘r009′, ’55′, ‘st001′, ‘t001′ union all
select ‘r010′, ’77′, ‘st004′, ‘t002′ union all
select ‘r011′, ’58′, ‘st005′, ‘t002′
———————————————————-
1.
select st_id
from students
where st_name = ‘王伟’
2.select st_id,st_name
from students
where st_name like ‘__燕%’
3 select st_name,len(st_name) as 名字长度
from students
where sex =’男’
4 select min(r_fenshu) as 最低分数
from teachers t inner join results r on t.t_id =r.r_tid
where t_lesson =’数学’ –这个是不考虑成绩中有null值的
5 select s.st_id as 学生编号,r_fenshu as分数,r_tid as 课目号
from students s inner join results r on s.st_id =r.r_stid
where s.sex=’女’
–如果还要课目的名称的话请用下面的
select s.st_id as 学生编号,r.r_fenshu as 分数,r.r_tid as 课目号,t.t_lesson as 课目名称
from students s inner join results r on s.st_id =r.r_stid
inner join teachers t on r.r_tid = t.t_id
where s.sex=’女’
6 select avg(r.r_fenshu)
from results r inner join teachers t on r.r_tid = t.t_id
where t.t_lesson=’英语’
7.select *
from students s inner join results r on s.st_id =r.r_stid
inner join teachers t on r.r_tid = t.t_id
where s.st_id in (select top 2 st_id from students order by st_id desc)
order by s.st_id desc
8 select