有学生成绩数据库 •学生(学号,姓名,年龄,性别,专业,平均学分积点) •课程(课程号,课名,学分) •成绩(学号,课程号,成绩,积点) 编写一个存储过程,完成统计学生的平均年龄。
时间: 2023-11-16 07:27:33 浏览: 105
好的,下面是一个统计学生平均年龄的Oracle存储过程:
```sql
CREATE OR REPLACE PROCEDURE CALCULATE_AVG_AGE(avg_age OUT NUMBER)
IS
total_age NUMBER := 0;
num_students NUMBER := 0;
avg_age_temp NUMBER := 0;
BEGIN
-- 遍历所有学生,计算总年龄和学生数量
FOR student IN (SELECT * FROM students) LOOP
total_age := total_age + student.age;
num_students := num_students + 1;
END LOOP;
-- 计算平均年龄
avg_age_temp := total_age / num_students;
-- 将平均年龄存入输出参数
avg_age := ROUND(avg_age_temp, 2);
END;
/
```
在这个存储过程中,我们首先使用 FOR 循环遍历所有学生,计算出总年龄和学生数量。然后,我们使用这些数据计算出平均年龄,并将其存入输出参数中。注意,在这个存储过程中,我们使用了 ROUND 函数将平均年龄保留两位小数。
相关问题
MySQL以数据库user_db及数据表student、teacher、class、course、sc为基础(11)查询信息技术学院的必修课和限选课的数量及平均学分; (12)查询每名学生的选课数量及平均成绩,按照平均成绩降序排列; (13)查询各门课程编号、选课人数及其及格率; (14)查询选课人数前五名的课程; (15)查询选修课程数最多和最少的学生的学号及选课数; 2、SQL子查询的应用; (1)查询信息技术学院年龄最大的学生的学号、姓名、性别; (2)查询每个院系年龄最大的学生的学号、姓名、性别、院系及年龄; (3)查询和“崔晓”一个院系的其他学生的学号、姓名、院系; (4)查询平均成绩在60分以上的课程及其平均成绩; (5)查询平均成绩大于“高莉”的平均成绩的学生学号、姓名及平均成绩; (6)查询课程的学分高于全体课程平均学分的课程编号、名称、学分及所属院系,查询结果按照学分降序排列; (7)查询至少有一名学生选修的所有课程的课程号及课程名;
11. 查询信息技术学院的必修课和限选课的数量及平均学分:
```
SELECT
SUM(CASE WHEN course_type = '必修' THEN 1 ELSE 0 END) AS required_course_count,
SUM(CASE WHEN course_type = '限选' THEN 1 ELSE 0 END) AS elective_course_count,
AVG(CASE WHEN course_type IN ('必修', '限选') THEN credit END) AS avg_credit
FROM
class
WHERE
department = '信息技术学院';
```
12. 查询每名学生的选课数量及平均成绩,按照平均成绩降序排列:
```
SELECT
sc.student_id,
COUNT(*) AS course_count,
AVG(score) AS avg_score
FROM
sc
JOIN
student ON student.id = sc.student_id
GROUP BY
sc.student_id
ORDER BY
avg_score DESC;
```
13. 查询各门课程编号、选课人数及其及格率:
```
SELECT
course_id,
COUNT(*) AS student_count,
SUM(CASE WHEN score >= 60 THEN 1 ELSE 0 END) / COUNT(*) AS pass_rate
FROM
sc
GROUP BY
course_id;
```
14. 查询选课人数前五名的课程:
```
SELECT
course_id,
COUNT(*) AS student_count
FROM
sc
GROUP BY
course_id
ORDER BY
student_count DESC
LIMIT 5;
```
15. 查询选修课程数最多和最少的学生的学号及选课数:
```
SELECT
student_id,
COUNT(*) AS course_count
FROM
sc
GROUP BY
student_id
HAVING
COUNT(*) = (SELECT MAX(cnt) FROM (SELECT COUNT(*) AS cnt FROM sc GROUP BY student_id) AS t)
OR COUNT(*) = (SELECT MIN(cnt) FROM (SELECT COUNT(*) AS cnt FROM sc GROUP BY student_id) AS t);
```
1. SQL子查询的应用:
(1) 查询信息技术学院年龄最大的学生的学号、姓名、性别:
```
SELECT
id, name, gender
FROM
student
WHERE
department = '信息技术学院' AND age = (SELECT MAX(age) FROM student WHERE department = '信息技术学院');
```
(2) 查询每个院系年龄最大的学生的学号、姓名、性别、院系及年龄:
```
SELECT
s.id, s.name, s.gender, s.age, s.department
FROM
student s
JOIN
(SELECT department, MAX(age) AS max_age FROM student GROUP BY department) t
ON
s.department = t.department AND s.age = t.max_age;
```
(3) 查询和“崔晓”一个院系的其他学生的学号、姓名、院系:
```
SELECT
id, name, department
FROM
student
WHERE
department = (SELECT department FROM student WHERE name = '崔晓') AND name != '崔晓';
```
(4) 查询平均成绩在60分以上的课程及其平均成绩:
```
SELECT
course_id,
AVG(score) AS avg_score
FROM
sc
WHERE
course_id IN (SELECT course_id FROM sc GROUP BY course_id HAVING AVG(score) >= 60)
GROUP BY
course_id;
```
(5) 查询平均成绩大于“高莉”的平均成绩的学生学号、姓名及平均成绩:
```
SELECT
id, name, AVG(score) AS avg_score
FROM
student
JOIN
sc ON student.id = sc.student_id
WHERE
AVG(score) > (SELECT AVG(score) FROM student JOIN sc ON student.id = sc.student_id WHERE name = '高莉')
GROUP BY
id, name;
```
(6) 查询课程的学分高于全体课程平均学分的课程编号、名称、学分及所属院系,查询结果按照学分降序排列:
```
SELECT
course.id, course.name, course.credit, course.department
FROM
course
WHERE
credit > (SELECT AVG(credit) FROM course)
ORDER BY
credit DESC;
```
(7) 查询至少有一名学生选修的所有课程的课程号及课程名:
```
SELECT
id, name
FROM
course
WHERE
id IN (SELECT DISTINCT course_id FROM sc);
```
有学生一课程关系数据库,各关系表描述如下: 学生(学号,姓名,性别,年龄,系)课程(课程号,课程名,先修课,学分)选课(学号,课程号,成绩) 用 SQL 语句实现下列问题 1、向学生选修课程表中插入元组"学生S6选修课程号C2"。2、查询每个学生的学号、姓名及其所选课程的课程名: 3、检索姓"李"且倒数第2个字为"华"字的学生的姓名和学号: 4、删除选课成绩在60分以下的学生记录; 5、把"大学英语"课程成绩提高5%; 6、求出男同学的每一年龄组(超过4人)有多少人? 7、定义视图 S _ age ,其中包括学生学号以及每个学生选修课程的门数(要求成绩非空)和平均成绩; 8、查询每个学生的选课总学分,要求列出学生学号和总学分(说明:考试成绩超过60才能获得此课程的学分) 9、查询计算机系成绩在80分以上的学生姓名、课程名和成绩,并按成绩降序排列结果; 10、查询既选修了"数据库"又选修了"操作系统"的学生学号及姓名。
1、向学生选修课程表中插入元组"学生S6选修课程号C2"。
```
INSERT INTO 选课 (学号, 课程号) VALUES ('S6', 'C2');
```
2、查询每个学生的学号、姓名及其所选课程的课程名:
```
SELECT 学生.学号, 学生.姓名, 课程.课程名
FROM 学生, 选课, 课程
WHERE 学生.学号 = 选课.学号 AND 选课.课程号 = 课程.课程号;
```
3、检索姓"李"且倒数第2个字为"华"字的学生的姓名和学号:
```
SELECT 学号, 姓名
FROM 学生
WHERE 姓名 LIKE '李%华_';
```
4、删除选课成绩在60分以下的学生记录:
```
DELETE FROM 选课
WHERE 成绩 < 60;
```
5、把"大学英语"课程成绩提高5%:
```
UPDATE 选课
SET 成绩 = 成绩 * 1.05
WHERE 课程号 = 'C1';
```
6、求出男同学的每一年龄组(超过4人)有多少人?
```
SELECT FLOOR(年龄 / 10) * 10 AS 年龄段, COUNT(*) AS 人数
FROM 学生
WHERE 性别 = '男'
GROUP BY 年龄段
HAVING COUNT(*) > 4;
```
7、定义视图 S_age ,其中包括学生学号以及每个学生选修课程的门数(要求成绩非空)和平均成绩;
```
CREATE VIEW S_age AS
SELECT 学号, COUNT(*) AS 选课门数, AVG(成绩) AS 平均成绩
FROM 选课
WHERE 成绩 IS NOT NULL
GROUP BY 学号;
```
8、查询每个学生的选课总学分,要求列出学生学号和总学分(说明:考试成绩超过60才能获得此课程的学分)
```
SELECT 选课.学号, SUM(课程.学分) AS 总学分
FROM 选课, 课程
WHERE 选课.课程号 = 课程.课程号 AND 成绩 > 60
GROUP BY 选课.学号;
```
9、查询计算机系成绩在80分以上的学生姓名、课程名和成绩,并按成绩降序排列结果;
```
SELECT 学生.姓名, 课程.课程名, 选课.成绩
FROM 学生, 选课, 课程
WHERE 学生.学号 = 选课.学号 AND 选课.课程号 = 课程.课程号 AND 学生.系 = '计算机系' AND 选课.成绩 > 80
ORDER BY 选课.成绩 DESC;
```
10、查询既选修了"数据库"又选修了"操作系统"的学生学号及姓名。
```
SELECT 学生.学号, 学生.姓名
FROM 学生, 选课 AS s1, 选课 AS s2
WHERE 学生.学号 = s1.学号 AND 学生.学号 = s2.学号 AND s1.课程号 = 'C1' AND s2.课程号 = 'C3';
```
阅读全文