SQL查询——同一张表的横向与纵向同时比较
2015-05-02 16:58
155 查看
表名:student
表结构及数据:
+----+--------+---------+------+------------+--------------+---------+
| id | name | english | math | birthday | native_place | chinese |
+----+--------+---------+------+------------+--------------+---------+
| 1 | 潘怡茹 | 86 | 91 | 1990-01-01 | 上海 | 97 |
| 2 | 刘濮松 | 88 | 68 | 1990-02-01 | 上海 | 96 |
| 3 | 刘吉如 | 85 | 53 | 1990-03-01 | 上海 | 70 |
| 4 | 李岩珂 | 85 | 70 | 1990-04-01 | 上海 | 96 |
| 5 | 王晓博 | 85 | 79 | 1990-05-01 | 上海 | 46 |
| 6 | 李帅旭 | 79 | 76 | 1990-06-01 | 上海 | 97 |
| 7 | 李静瑶 | 89 | 61 | 1990-07-01 | 上海 | 92 |
| 8 | 金纾凡 | 80 | 43 | 1990-08-01 | 上海 | 83 |
| 9 | 秦梓航 | 57 | 46 | 1990-09-01 | 上海 | 86 |
| 10 | 关颖利 | 80 | 77 | 1991-01-01 | 上海 | 84 |
+----+--------+---------+------+------------+--------------+---------+
需求:在该表中查出最偏科的学生姓名。
分析:
这张表中有三个科目:English、math、Chinese
1-求出三个科目的分数差(求绝对值)——使用abs(math-english) abs(chinese-english) abs(math-chinese)
2-求出整个班级中 数学与英语的分数差、语文与英语的分数差、数学与英语的分数差 的最大值——max(abs(math-english) )、 max(abs(chinese-english)) 、 max(abs(math-chinese))
3-在2的结果中查找出数值最大的值
4-在student表中搜索
数学与英语的分数差 等于 (3-的结果)
语文与英语的分数差 等于 (3-的结果)
数学与英语的分数差 等于 (3-的结果)
如此可以查找出最偏科的学生姓名。
SQL代码:
select name from student
where
abs(chinese-math) in (select max(tmp.score)
from (
select max(abs(s1.chinese-s1.math)) score from student s1
union select max(abs(s2.chinese-s2.english)) score from student s2
union select max(abs(s3.english-s3.math)) score from student s3
) tmp)
or
abs(chinese-english)in (select max(tmp1.score)
from (
select max(abs(s1.chinese-s1.math)) score from student s1
union select max(abs(s2.chinese-s2.english)) score from student s2
union select max(abs(s3.english-s3.math)) score from student s3
) tmp1)
or
abs(english-math) in (select max(tmp2.score)
from (
select max(abs(s1.chinese-s1.math)) score from student s1
union select max(abs(s2.chinese-s2.english)) score from student s2
union select max(abs(s3.english-s3.math)) score from student s3
) tmp2);
表结构及数据:
+----+--------+---------+------+------------+--------------+---------+
| id | name | english | math | birthday | native_place | chinese |
+----+--------+---------+------+------------+--------------+---------+
| 1 | 潘怡茹 | 86 | 91 | 1990-01-01 | 上海 | 97 |
| 2 | 刘濮松 | 88 | 68 | 1990-02-01 | 上海 | 96 |
| 3 | 刘吉如 | 85 | 53 | 1990-03-01 | 上海 | 70 |
| 4 | 李岩珂 | 85 | 70 | 1990-04-01 | 上海 | 96 |
| 5 | 王晓博 | 85 | 79 | 1990-05-01 | 上海 | 46 |
| 6 | 李帅旭 | 79 | 76 | 1990-06-01 | 上海 | 97 |
| 7 | 李静瑶 | 89 | 61 | 1990-07-01 | 上海 | 92 |
| 8 | 金纾凡 | 80 | 43 | 1990-08-01 | 上海 | 83 |
| 9 | 秦梓航 | 57 | 46 | 1990-09-01 | 上海 | 86 |
| 10 | 关颖利 | 80 | 77 | 1991-01-01 | 上海 | 84 |
+----+--------+---------+------+------------+--------------+---------+
需求:在该表中查出最偏科的学生姓名。
分析:
这张表中有三个科目:English、math、Chinese
1-求出三个科目的分数差(求绝对值)——使用abs(math-english) abs(chinese-english) abs(math-chinese)
2-求出整个班级中 数学与英语的分数差、语文与英语的分数差、数学与英语的分数差 的最大值——max(abs(math-english) )、 max(abs(chinese-english)) 、 max(abs(math-chinese))
3-在2的结果中查找出数值最大的值
4-在student表中搜索
数学与英语的分数差 等于 (3-的结果)
语文与英语的分数差 等于 (3-的结果)
数学与英语的分数差 等于 (3-的结果)
如此可以查找出最偏科的学生姓名。
SQL代码:
select name from student
where
abs(chinese-math) in (select max(tmp.score)
from (
select max(abs(s1.chinese-s1.math)) score from student s1
union select max(abs(s2.chinese-s2.english)) score from student s2
union select max(abs(s3.english-s3.math)) score from student s3
) tmp)
or
abs(chinese-english)in (select max(tmp1.score)
from (
select max(abs(s1.chinese-s1.math)) score from student s1
union select max(abs(s2.chinese-s2.english)) score from student s2
union select max(abs(s3.english-s3.math)) score from student s3
) tmp1)
or
abs(english-math) in (select max(tmp2.score)
from (
select max(abs(s1.chinese-s1.math)) score from student s1
union select max(abs(s2.chinese-s2.english)) score from student s2
union select max(abs(s3.english-s3.math)) score from student s3
) tmp2);
相关文章推荐
- 自定义scrollview实现类似地图横向纵向同时滚动
- extjs 3.4 在IE8下,tabPanel会同时出现纵向、横向滚动条的情况。影响用户体验。
- 用OO方法开发ALV(实现横向alv head,与纵向ALV head比较相似,只有少许不同)
- Java: I/O(1/3)字节流与字符流的纵向与横向比较
- 数据库同一张表字段横向与纵向相加
- 什么叫横向比较和纵向比较
- 在浏览器窗口大小变化时,自动出现或隐藏滚动条,隐藏横向滚动条,仅保留纵向的
- 转mysql横向扩展和纵向扩展
- 如何控制横向和纵向滚动条的显隐?
- 使用Lua 局部变量来优化性能,同时比较局部变量和全局变量
- [有明信息]横向集成、纵向贯通 ——地产财务管理新思路
- Scale-up(纵向扩展) vs Scale-out(横向扩展)
- 旧文新帖(First out:2008-06-07):JavaScript“类”继承的横向比较
- 求sql查询语句(转换数据表由纵向转换成横向)
- jQuery自定义风格各异的横向或纵向内容滚动条效果
- 关于软件开发项目任务的横向分解和纵向分解
- 批处理基础1——横向创建n层目录,纵向创建m层目录
- Silverlight打印全套解决方案--支持打印预览、页面设置(横向纵向,页边距,纸张大小、字体大小)、自动分页和多页连续打印
- Word2007:如何在竖版(纵向)页面中间插入横版(横向)页面
- SQLite数据库中用insert同时插入多条记录的方法和效率比较