SId 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别
CId 课程编号,Cname 课程名称,TId 教师编号
TId 教师编号,Tname 教师姓名
SId 学生编号,CId 课程编号,score 分数
create table Student(SId varchar (10),Sname varchar (10),Sage datetime,Ssex varchar (10));
insert into Student values ('01','赵雷','1990-01-01','男');
insert into Student values ('02','钱电','1990-12-21','男');
insert into Student values ('03','孙风','1990-12-20','男');
insert into Student values ('04','李云','1990-12-06','男');
insert into Student values ('05','周梅','1991-12-01','女');
insert into Student values ('06','吴兰','1992-01-01','女');
insert into Student values ('07','郑竹','1989-01-01','女');
insert into Student values ('09','张三','2017-12-20','女');
insert into Student values ('10','李四','2017-12-25','女');
insert into Student values ('11','李四','2012-06-06','女');
insert into Student values ('12','赵六','2013-06-13','女');
insert into Student values ('13','孙七','2014-06-01','女');
create table Course(CId varchar (10),Cname nvarchar(10),TId varchar (10));
insert into Course values ('01','语文','02');
insert into Course values ('02','数学','01');
insert into Course values ('03','英语','03');
create table Teacher(TId varchar (10),Tname varchar (10));
insert into Teacher values ('01','张三');
insert into Teacher values ('02','李四');
insert into Teacher values ('03','王五');
create table SC(SId varchar (10),CId varchar (10),score decimal (18,1));
insert into SC values ('01','01', 80 );
insert into SC values ('01','02', 90 );
insert into SC values ('01','03', 99 );
insert into SC values ('02','01', 70 );
insert into SC values ('02','02', 60 );
insert into SC values ('02','03', 80 );
insert into SC values ('03','01', 80 );
insert into SC values ('03','02', 80 );
insert into SC values ('03','03', 80 );
insert into SC values ('04','01', 50 );
insert into SC values ('04','02', 30 );
insert into SC values ('04','03', 20 );
insert into SC values ('05','01', 76 );
insert into SC values ('05','02', 87 );
insert into SC values ('06','01', 31 );
insert into SC values ('06','03', 34 );
insert into SC values ('07','02', 89 );
insert into SC values ('07','03', 98 );
# right join
SELECT *
FROM Student
RIGHT JOIN (
SELECT t1.SId, class1, class2
FROM (
SELECT SId, score AS class1
FROM sc
WHERE sc.CId = '01'
) t1, (
SELECT SId, score AS class2
FROM sc
WHERE sc.CId = '02'
) t2
WHERE t1.SId = t2.SId
AND t1.class1 > t2.class2
) r
ON Student.SId = r.SId;
# left join
SELECT *
FROM (
SELECT t1.SId, class1, class2
FROM (
SELECT SId, score AS class1
FROM sc
WHERE sc.CId = '01'
) t1, (
SELECT SId, score AS class2
FROM sc
WHERE sc.CId = '02'
) t2
WHERE t1.SId = t2.SId
AND t1.class1 > t2.class2
) r
LEFT JOIN Student ON Student.SId = r.SId;
SELECT *
FROM (
SELECT *
FROM sc
WHERE sc.CId = '01'
) t1, (
SELECT *
FROM sc
WHERE sc.CId = '02'
) t2
WHERE t1.SId = t2.SId;
SELECT *
FROM (
SELECT *
FROM sc
WHERE sc.CId = '01'
) t1
LEFT JOIN (
SELECT *
FROM sc
WHERE sc.CId = '02'
) t2
ON t1.SId = t2.SId;
SELECT *
FROM (
SELECT *
FROM sc
WHERE sc.CId = '02'
) t2
RIGHT JOIN (
SELECT *
FROM sc
WHERE sc.CId = '01'
) t1
ON t1.SId = t2.SId;
SELECT *
FROM sc
WHERE sc.SId NOT IN (
SELECT SId
FROM sc
WHERE sc.CId = '01'
)
AND sc.CId = '02';
SELECT student.SId, sname, ss
FROM student, (
SELECT SId, AVG(score) AS ss
FROM sc
GROUP BY SId
HAVING AVG(score) > 60
) r
WHERE student.sid = r.sid;
SELECT Student.SId, Student.Sname, r.ss
FROM Student
RIGHT JOIN (
SELECT SId, AVG(score) AS ss
FROM sc
GROUP BY SId
HAVING AVG(score) > 60
) r
ON Student.SId = r.SId;
SELECT s.SId, ss, Sname
FROM (
SELECT SId, AVG(score) AS ss
FROM sc
GROUP BY SId
HAVING AVG(score) > 60
) r
LEFT JOIN (
SELECT Student.SId, Student.Sname
FROM Student
) s
ON s.SId = r.SId;
SELECT student.sid, student.sname, r.coursenumber, r.scoresum
FROM student, (
SELECT sc.sid, sum(sc.score) AS scoresum, count(sc.cid) AS coursenumber
FROM sc
GROUP BY sc.sid
) r
WHERE student.sid = r.sid;
如要显示没选课的学生(显示为 NULL),需要使用 join:
SELECT s.sid, s.sname, r.coursenumber, r.scoresum
FROM (
SELECT student.sid, student.sname
FROM student
) s
LEFT JOIN (
SELECT sc.sid, sum(sc.score) AS scoresum, count(sc.cid) AS coursenumber
FROM sc
GROUP BY sc.sid
) r
ON s.sid = r.sid;
SELECT *
FROM student
WHERE EXISTS (
SELECT sc.sid
FROM sc
WHERE student.sid = sc.sid
);
SELECT *
FROM student
WHERE student.sid IN (
SELECT sc.sid
FROM sc
);
SELECT count(*)
FROM teacher
WHERE tname LIKE '李%';
SELECT student.*
FROM student, teacher, course, sc
WHERE student.sid = sc.sid
AND course.cid = sc.cid
AND course.tid = teacher.tid
AND tname = '张三';
SELECT *
FROM student
WHERE student.sid NOT IN (
SELECT sc.sid
FROM sc
GROUP BY sc.sid
HAVING count(sc.cid) = (
SELECT count(cid)
FROM course
)
);
SELECT *
FROM student
WHERE student.sid IN (
SELECT sc.sid
FROM sc
WHERE sc.cid IN (
SELECT sc.cid
FROM sc
WHERE sc.sid = '01'
)
);
SELECT *
FROM student
WHERE student.sid NOT IN (
SELECT sc.sid
FROM sc
WHERE sc.cid IN (
SELECT course.cid
FROM course
WHERE course.tid IN (
SELECT teacher.tid
FROM teacher
WHERE tname = '张三'
)
)
);
SELECT *
FROM student
WHERE student.sid NOT IN (
SELECT sc.sid
FROM sc, course, teacher
WHERE sc.cid = course.cid
AND course.tid = teacher.tid
AND teacher.tname = '张三'
);
SELECT student.sid, student.sname, AVG(sc.score)
FROM student, sc
WHERE student.sid = sc.sid
AND sc.score < 60
GROUP BY sc.sid
HAVING count(*) > 1;
SELECT student.*, sc.score
FROM student, sc
WHERE student.sid = sc.sid
AND sc.score < 60
AND cid = '01'
ORDER BY sc.score DESC;
SELECT *
FROM sc
LEFT JOIN (
SELECT sid, avg(score) AS avscore
FROM sc
GROUP BY sid
) r
ON sc.sid = r.sid
ORDER BY avscore DESC;
SELECT sc.CId, max(sc.score) AS 最高分, min(sc.score) AS 最低分
, AVG(sc.score) AS 平均分, count(*) AS 选修人数
, sum(CASE
WHEN sc.score >= 60 THEN 1
ELSE 0
END) / count(*) AS 及格率
, sum(CASE
WHEN sc.score >= 70
AND sc.score < 80
THEN 1
ELSE 0
END) / count(*) AS 中等率
, sum(CASE
WHEN sc.score >= 80
AND sc.score < 90
THEN 1
ELSE 0
END) / count(*) AS 优良率
, sum(CASE
WHEN sc.score >= 90 THEN 1
ELSE 0
END) / count(*) AS 优秀率
FROM sc
GROUP BY sc.CId
ORDER BY count(*) DESC, sc.CId ASC
SELECT a.cid, a.sid, a.score
, count(b.score) + 1 AS rank
FROM sc a
LEFT JOIN sc b
ON a.score < b.score
AND a.cid = b.cid
GROUP BY a.cid, a.sid, a.score
ORDER BY a.cid, rank ASC;
SET @crank = 0;
SELECT q.sid, total, @crank := @crank + 1 AS rank
FROM (
SELECT sc.sid, sum(sc.score) AS total
FROM sc
GROUP BY sc.sid
ORDER BY total DESC
) q;
SELECT course.cname, course.cid
, sum(CASE
WHEN sc.score <= 100
AND sc.score > 85
THEN 1
ELSE 0
END) AS "[100-85]"
, sum(CASE
WHEN sc.score <= 85
AND sc.score > 70
THEN 1
ELSE 0
END) AS "[85-70]"
, sum(CASE
WHEN sc.score <= 70
AND sc.score > 60
THEN 1
ELSE 0
END) AS "[70-60]"
, sum(CASE
WHEN sc.score <= 60
AND sc.score > 0
THEN 1
ELSE 0
END) AS "[60-0]"
FROM sc
LEFT JOIN course ON sc.cid = course.cid
GROUP BY sc.cid;
SELECT *
FROM sc
WHERE (
SELECT count(*)
FROM sc a
WHERE sc.cid = a.cid
AND sc.score < a.score
) < 3
ORDER BY cid ASC, sc.score DESC;
第二种比较灵巧一些,用自身左交,但是有点难以理解。先用自己交自己,条件为a.cid=b.cidanda.score<b.score,其实就是列出同一门课内所有分数比较的情况。想要查看完整的表可以
SELECT *
FROM sc a
LEFT JOIN sc b
ON a.cid = b.cid
AND a.score < b.score
ORDER BY a.cid, a.score;
结果
查看,发现结果是 47 行的一个表,列出了类似 01 号课里“ 30 分小于 50 ,也小于 70 ,也
小于 80 ,也小于 90 ”“ 50 分小于 70 ,小于 80 ,小于 90 ”.....
所以理论上,对任何一门课来说,分数最高的那三个记录,在这张大表里,通过a.sid和a.cid
可以联合确定这个同学的这门课的这个分数究竟比多少个其他记录高/低,
如果这个特定的a.sid和a.cid组合出现在这张表里的次数少于 3 个,那就意味着这个组合
(学号+课号+分数)是这门课里排名前三的。
所以下面这个计算中 having count 部分其实 count() 或者任意其他列都可以,这里制定了
一个列只是因为比 count() 运行速度上更快。
SELECT a.sid, a.cid, a.score
FROM sc a
LEFT JOIN sc b
ON a.cid = b.cid
AND a.score < b.score
GROUP BY a.cid, a.sid
HAVING count(b.cid) < 3
ORDER BY a.cid;
SELECT cid, count(sid)
FROM sc
GROUP BY cid;
SELECT student.sid, student.sname
FROM student
WHERE student.sid IN (
SELECT sc.sid
FROM sc
GROUP BY sc.sid
HAVING count(sc.cid) = 2
);
联合查询
SELECT student.SId, student.Sname
FROM sc, student
WHERE student.SId = sc.SId
GROUP BY sc.SId
HAVING count(*) = 2;
SELECT ssex, count(*)
FROM student
GROUP BY ssex;
SELECT *
FROM student
WHERE student.Sname LIKE '%风%'
SELECT sname, count(*)
FROM student
GROUP BY sname
HAVING count(*) > 1;
嵌套查询列出同名的全部学生的信息
SELECT *
FROM student
WHERE sname IN (
SELECT sname
FROM student
GROUP BY sname
HAVING count(*) > 1
);
SELECT *
FROM student
WHERE YEAR(student.Sage) = 1990;
SELECT sc.cid, course.cname, AVG(SC.SCORE) AS average
FROM sc, course
WHERE sc.cid = course.cid
GROUP BY sc.cid
ORDER BY average DESC, cid ASC;
SELECT student.sid, student.sname, AVG(sc.score) AS aver
FROM student, sc
WHERE student.sid = sc.sid
GROUP BY sc.sid
HAVING aver > 85;
SELECT student.sname, sc.score
FROM student, sc, course
WHERE student.sid = sc.sid
AND course.cid = sc.cid
AND course.cname = '数学'
AND sc.score < 60;
SELECT student.sname, cid, score
FROM student
LEFT JOIN sc ON student.sid = sc.sid;
SELECT student.sname, course.cname, sc.score
FROM student, course, sc
WHERE sc.score > 70
AND student.sid = sc.sid
AND sc.cid = course.cid;
SELECT cid
FROM sc
WHERE score < 60
GROUP BY cid;
SELECT DISTINCT sc.CId
FROM sc
WHERE sc.score < 60;
SELECT student.sid, student.sname
FROM student, sc
WHERE cid = '01'
AND score >= 80
AND student.sid = sc.sid;
SELECT sc.CId, count(*) AS 学生人数
FROM sc
GROUP BY sc.CId;
SELECT student.*, sc.score, sc.cid
FROM student, teacher, course, sc
WHERE teacher.tid = course.tid
AND sc.sid = student.sid
AND sc.cid = course.cid
AND teacher.tname = '张三'
HAVING max(sc.score);
SELECT student.*, sc.score, sc.cid
FROM student, teacher, course, sc
WHERE teacher.tid = course.tid
AND sc.sid = student.sid
AND sc.cid = course.cid
AND teacher.tname = '张三'
ORDER BY score DESC
LIMIT 1;
SELECT student.*, sc.score, sc.cid
FROM student, teacher, course, sc
WHERE teacher.tid = course.tid
AND sc.sid = student.sid
AND sc.cid = course.cid
AND teacher.tname = '张三'
AND sc.score = (
SELECT Max(sc.score)
FROM sc, student, teacher, course
WHERE teacher.tid = course.tid
AND sc.sid = student.sid
AND sc.cid = course.cid
AND teacher.tname = '张三'
);
SELECT a.cid, a.sid, a.score
FROM sc a
INNER JOIN sc b
ON a.sid = b.sid
AND a.cid != b.cid
AND a.score = b.score
GROUP BY cid, sid;
SELECT a.sid, a.cid, a.score
FROM sc a
LEFT JOIN sc b
ON a.cid = b.cid
AND a.score < b.score
GROUP BY a.cid, a.sid
HAVING count(b.cid) < 2
ORDER BY a.cid;
SELECT sc.cid, count(sid) AS cc
FROM sc
GROUP BY cid
HAVING cc > 5;
SELECT sid, count(cid) AS cc
FROM sc
GROUP BY sid
HAVING cc >= 2;
SELECT student.*
FROM sc, student
WHERE sc.SId = student.SId
GROUP BY sc.SId
HAVING count(*) = (
SELECT DISTINCT count(*)
FROM course
)
SELECT student.SId AS 学生编号, student.Sname AS 学生姓名
, TIMESTAMPDIFF(YEAR, student.Sage, CURDATE()) AS 学生年龄
FROM student
SELECT *
FROM student
WHERE WEEKOFYEAR(student.Sage) = WEEKOFYEAR(CURDATE());
SELECT *
FROM student
WHERE WEEKOFYEAR(student.Sage) = WEEKOFYEAR(CURDATE()) + 1;
SELECT *
FROM student
WHERE MONTH(student.Sage) = MONTH(CURDATE());
SELECT *
FROM student
WHERE MONTH(student.Sage) = MONTH(CURDATE()) + 1;
作者: C you again,从事软件开发 努力在IT搬砖路上的技术小白 公众号: 【C you again】,分享计算机类毕业设计源码、IT技术文章、游戏源码、网页模板、程序人生等等 关于转载:欢迎转载博主文章,转载时标明出处 求赞环节:创作不易,记得 点赞评论转发 谢谢你一路支持
我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这
如果我使用ruby版本2.5.1和Rails版本2.3.18会怎样?我有基于rails2.3.18和ruby1.9.2p320构建的rails应用程序,我只想升级ruby的版本,而不是rails,这可能吗?我必须面对哪些挑战? 最佳答案 GitHub维护apublicfork它有针对旧Rails版本的分支,有各种变化,它们一直在运行。有一段时间,他们在较新的Ruby版本上运行较旧的Rails版本,而不是最初支持的版本,因此您可能会发现一些关于需要向后移植的有用提示。不过,他们现在已经有几年没有使用2.3了,所以充其量只能让更
我安装了ruby版本管理器,并将RVM安装的ruby实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby。有没有办法让emacs像shell一样尊重ruby的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el
有人知道在发布新版本的Ruby和Rails时收到电子邮件的方法吗?他们有邮件列表,RubyonRails有一个推特,但我不想听到那些随之而来的喧嚣,我只想知道什么时候发布新版本,尤其是那些有安全修复的版本。 最佳答案 从therailsblog获取提要.http://weblog.rubyonrails.org/feed/atom.xml 关于ruby-on-rails-如何在发布新的Ruby或Rails版本时收到通知?,我们在StackOverflow上找到一个类似的问题:
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co
嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来
目录第1题连续问题分析:解法:第2题分组问题分析:解法:第3题间隔连续问题分析:解法:第4题打折日期交叉问题分析:解法:第5题同时在线问题分析:解法:第1题连续问题如下数据为蚂蚁森林中用户领取的减少碳排放量iddtlowcarbon10012021-12-1212310022021-12-124510012021-12-134310012021-12-134510012021-12-132310022021-12-144510012021-12-1423010022021-12-154510012021-12-1523.......找出连续3天及以上减少碳排放量在100以上的用户分析:遇到这类
1.在Python3中,下列关于数学运算结果正确的是:(B)a=10b=3print(a//b)print(a%b)print(a/b)A.3,3,3.3333...B.3,1,3.3333...C.3.3333...,3.3333...,3D.3.3333...,1,3.3333...解析: 在Python中,//表示地板除(向下取整),%表示取余,/表示除(Python2向下取整返回3)2.如下程序Python2会打印多少个数:(D)k=1000whilek>1: print(k)k=k/2A.1000 B.10C.11D.9解析: 按照题意每次循环K/2,直到K值小于等