MySQL上运行 select distinct sno from sc where grade>90 and grade<100
时间: 2024-02-25 16:56:30 浏览: 79
你的问题是关于 MySQL 数据库的查询语句,查询的是表 sc 中成绩在 90 到 100 之间的学生学号。可以使用以下 SQL 语句来实现这个查询:
```
SELECT DISTINCT sno FROM sc WHERE grade > 90 AND grade < 100
```
其中,`SELECT DISTINCT sno` 表示要查询表 sc 中不重复的学生学号,`FROM sc` 表示要从表 sc 中进行查询,`WHERE grade > 90 AND grade < 100` 表示要查询符合条件的记录,即成绩在 90 到 100 之间的学生。
相关问题
.创建存储过程no_jg,实现将选修指定号课程的学生的grade1的不及格率控制在指定范围内,制定了如下加分规则:每人都加5分,看是否满足不及格率在指定范围以下,如果没有,则每人再加5分,再看是否满足,如此反复加分,直到满足条件为止。 执行存储过程no_jg,要求将K001的grade1成绩的不及格率控制在20%以内。
首先,我们需要创建一个存储过程来实现上述需求:
```mysql
DELIMITER $$
CREATE PROCEDURE no_jg (IN course_no VARCHAR(10), IN max_fail_rate FLOAT)
BEGIN
DECLARE current_fail_rate FLOAT DEFAULT 1;
DECLARE add_score INT DEFAULT 5;
WHILE current_fail_rate > max_fail_rate DO
UPDATE student SET grade1 = grade1 + add_score
WHERE sno IN (
SELECT DISTINCT sc.sno FROM sc
WHERE sc.cno = course_no AND sc.grade < 60
);
SELECT COUNT(*) INTO @fail_count FROM sc
WHERE cno = course_no AND grade < 60;
SELECT COUNT(*) INTO @total_count FROM sc
WHERE cno = course_no;
SET current_fail_rate = @fail_count / @total_count;
SET add_score = add_score + 5;
END WHILE;
END $$
DELIMITER ;
```
然后,我们可以调用存储过程no_jg来将K001的grade1成绩的不及格率控制在20%以内:
```mysql
CALL no_jg('K001', 0.20);
```
也就是说,我们要求在不及格率小于等于20%的情况下,不断给K001的学生们加5分,直到满足条件为止。如果不及格率一开始就小于等于20%,则不会进行任何操作。
mysql 查询选修了全部学分大于4的课程的学生的学号
可以使用如下 SQL 查询语句:
SELECT DISTINCT sc.Sno
FROM sc
WHERE sc.Credit > 4
GROUP BY sc.Sno
HAVING SUM(sc.Grade) >= 60
这个查询语句可以找出所有选修了全部学分大于4的课程的学生的学号。需要注意的是,这个查询语句假设每门课程的学分相等,且及格分数为60分,如果不符合实际情况,需要进行相应的修改。
阅读全文