create database StudCourse; use StudCourse; #Student(Sid,Sname,Sage,Ssex) 学生表 CREATE TABLE student ( sid varchar(10) NOT NULL, sName varchar(20) DEFAULT NULL, sAge datetime DEFAULT '1980-10-12 23:12:36', sSex varchar(10) DEFAULT NULL, PRIMARY KEY (sid) ) ENGINE=InnoDB DEFAULT CHA-RSET=utf8; #Course(Cid,Cname,Tid) 课程表 CREATE TABLE course ( cid varchar(10) NOT NULL, cName varchar(10) DEFAULT NULL, tid int(20) DEFAULT NULL, PRIMARY KEY (cid) ) ENGINE=InnoDB DEFAULT CHA-RSET=utf8; #SC(Sid,Cid,score) 成绩表 CREATE TABLE sc ( sid varchar(10) DEFAULT NULL, cid varchar(10) DEFAULT NULL, score int(10) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHA-RSET=utf8; #Teacher(Tid,Tname) 教师表 CREATE TABLE teacher ( tid int(10) DEFAULT NULL, tName varchar(10) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHA-RSET=utf8; #数据:( MySQL ) insert into teacher(tid,tName) values (1,' 李老师'),(2,' 何以琛'),(3,' 叶平'); insert into student(sid,sName,sAge,sSex) values ('1001',' 张三丰 ','1980-10-12 23:12:36',' 男'),('1002',' 张无极 ','1995-10-12 23:12:36',' 男'),('1003',' 李奎','1992-10-12 23:12:36',' 女'),('1004',' 李元宝 ','1980-10-12 23:12:36',' 女'),('1005',' 李世明','1981-10-12 23:12:36',' 男'),('1006',' 赵六','1986-10-12 23:12:36',' 男'),('1007',' 田七','1981-10-12 23:12:36',' 女'), ('1008',' 张三丰 ','1982-08-12 23:12:36',' 男'); insert into sc(sid,cid,score) values ('1','001',80),('1001','002',60),('1001','003',75),('1002','001',85),('1002','002',70),('1003','004',100), ('1003','001',90),('1003','002',55),('1004','002',65),('1004','003',60); insert into course(cid,cName,tid) values ('001',' 企业管理 ',3),('002',' 马克思 ',3),('003','UML',2),('004',' 数据库 ',1),('005','英语',1);
时间: 2023-08-20 10:29:33 浏览: 145
好的,感谢提供数据库信息。下面是 SQL 查询语句,可以实现您的要求:
```
SELECT c.cid, c.cName,
SUM(CASE WHEN s.score >= 85 AND s.score <= 100 THEN 1 ELSE 0 END) AS '100-85',
SUM(CASE WHEN s.score >= 70 AND s.score < 85 THEN 1 ELSE 0 END) AS '85-70',
SUM(CASE WHEN s.score >= 60 AND s.score < 70 THEN 1 ELSE 0 END) AS '70-60',
SUM(CASE WHEN s.score < 60 THEN 1 ELSE 0 END) AS '<60'
FROM course c
INNER JOIN sc s ON c.cid = s.cid
GROUP BY c.cid, c.cName;
```
以上 SQL 查询语句会统计每个课程的成绩分布情况,其中 `100-85` 表示分数在 85 到 100 之间的学生人数,`85-70` 表示分数在 70 到 85 之间的学生人数,`70-60` 表示分数在 60 到 70 之间的学生人数,`<60` 表示分数小于 60 的学生人数。请根据您的实际情况进行调整。
相关问题
1.学生表 create table student ( sid varchar(16),---学号 sname varchar(32),--学生姓名 sage int,---学生年龄 ssex varchar(16)---学生性别 ) 2.课程表 create table course ( cid varchar(16),--课程编号 cname varchar(32),--课程名称 tid varchar(16)---教师编号 ) 3.成绩表 create table course ( sid varchar(16),--学号 cid varchar(32),--课程编号 score int---成绩 ) 4.教师表 create table teacher ( tid varchar(16),--教师编号 tname varchar(32)--教师名字) 查询成绩大于85分的学生姓名
可以使用以下 SQL 语句查询成绩大于85分的学生姓名:
SELECT sname FROM student, score WHERE student.sid = score.sid AND score.score > 85;
建学生表 Student(SId,Sname,Ssex,Dno) SId 学号(唯一),主键 Sname 学生姓名,非空 Ssex 性别为男或女,默认为“男” Dno 学生所在系(外键),参考departmen表中的 Dno 列
SQL语句如下:
```
CREATE TABLE Student (
SId CHAR(10) PRIMARY KEY,
Sname VARCHAR(20) NOT NULL,
Ssex CHAR(2) DEFAULT '男' CHECK (Ssex IN ('男', '女')),
Dno CHAR(10) REFERENCES department(Dno)
);
```
其中,SId为CHAR类型,长度为10,作为主键;Sname为VARCHAR类型,长度为20,不能为空;Ssex为CHAR类型,长度为2,有默认值"男",且只能取"男"或"女"两个值;Dno为CHAR类型,长度为10,作为外键,参考department表中的Dno列。
阅读全文