美文网首页
mysql 练习3

mysql 练习3

作者: 夜空最亮的9星 | 来源:发表于2018-06-20 18:09 被阅读6次

建表语句

CREATE TABLE `test1` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, `course` varchar(20) DEFAULT NULL, `score` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

插入数据

insert into test1(name,course,score) values ('张三','语文',80), ('李四','语文',90), ('王五','语文',93), ('张三','数学',77), ('李四','数学',68), ('王五','数学',99), ('张三','英语',90), ('李四','英语',50), ('王五','英语',89);

查看结果

mysql> select * from test1;
+----+--------+--------+-------+
| id | name   | course | score |
+----+--------+--------+-------+
| 10 | 张三   | 语文   |    80 |
| 11 | 李四   | 语文   |    90 |
| 12 | 王五   | 语文   |    93 |
| 13 | 张三   | 数学   |    77 |
| 14 | 李四   | 数学   |    68 |
| 15 | 王五   | 数学   |    99 |
| 16 | 张三   | 英语   |    90 |
| 17 | 李四   | 英语   |    50 |
| 18 | 王五   | 英语   |    89 |
+----+--------+--------+-------+
9 rows in set (0.00 sec)

TOP N
N>=1

查询每门课程前两名的学生以及成绩

1、使用union all

如果结果集比较小,可以用程序查询单个分组结果后拼凑,也可以使用union all

mysql> (select name,course,score from test1 where course='语文' order by score desc limit 2)
    -> union all
    -> (select name,course,score from test1 where course='数学' order by score desc limit 2)
    -> union all
    -> (select name,course,score from test1 where course='英语' order by score desc limit 2);
+--------+--------+-------+
| name   | course | score |
+--------+--------+-------+
| 王五   | 语文   |    93 |
| 李四   | 语文   |    90 |
| 王五   | 数学   |    99 |
| 张三   | 数学   |    77 |
| 张三   | 英语   |    90 |
| 王五   | 英语   |    89 |
+--------+--------+-------+
6 rows in set (0.01 sec)

2、自身左连接

mysql> select a.name,a.course,a.score
    -> from test1 a left join test1 b on a.course=b.course and a.score<b.score
    -> group by a.name,a.course,a.score
    -> having count(b.id)<2
    -> order by a.course,a.score desc;
+--------+--------+-------+
| name   | course | score |
+--------+--------+-------+
| 王五   | 数学   |    99 |
| 张三   | 数学   |    77 |
| 张三   | 英语   |    90 |
| 王五   | 英语   |    89 |
| 王五   | 语文   |    93 |
| 李四   | 语文   |    90 |
+--------+--------+-------+
6 rows in set (0.00 sec)

3、相关子查询

mysql> select *
    -> from test1 a
    -> where 2>(select count(*) from test1 where course=a.course and score>a.score)
    -> order by a.course,a.score desc;
+----+--------+--------+-------+
| id | name   | course | score |
+----+--------+--------+-------+
|  6 | 王五   | 数学   |    99 |
|  4 | 张三   | 数学   |    77 |
|  7 | 张三   | 英语   |    90 |
|  9 | 王五   | 英语   |    89 |
|  3 | 王五   | 语文   |    93 |
|  2 | 李四   | 语文   |    90 |
+----+--------+--------+-------+
6 rows in set (0.01 sec)

4、使用用户变量

mysql> set @num := 0, @course := '';
Query OK, 0 rows affected (0.00 sec)

mysql> 
mysql> select name, course, score
    -> from (
    ->    select name, course, score,
    ->       @num := if(@course = course, @num + 1, 1) as row_number,
    ->       @course := course as dummy
    ->   from test1
    ->   order by course, score desc
    -> ) as x where x.row_number <= 2;
+--------+--------+-------+
| name   | course | score |
+--------+--------+-------+
| 王五   | 数学   |    99 |
| 张三   | 数学   |    77 |
| 张三   | 英语   |    90 |
| 王五   | 英语   |    89 |
| 王五   | 语文   |    93 |
| 李四   | 语文   |    90 |
+--------+--------+-------+
6 rows in set (0.00 sec)

相关文章

  • mysql 练习3

    建表语句 插入数据 查看结果 TOP NN>=1 查询每门课程前两名的学生以及成绩 1、使用union all 如...

  • sql 练习(二)

    环境是mysql 练习数据见SQL:练习的前期准备 sql 练习(一) 11、查询‘3-105’号课程的平均分 1...

  • MySQL Operation

    sql语句练习sql练习2 MYSQL导入数据出现The MySQL server is running with...

  • MySQL 数据库SQL练习

    title: MySQL 数据库SQL练习tags: MySQL,练习grammar_cjkRuby: true ...

  • 数据库语言杂记

    MySQL ORDER BY 排序 IF 及 IN 字符串连接函数concat() MySQL练习题:练习题一 ...

  • mysql练习题3

    **问题:**MySQL中的varchar和char有什么区别? 有三种区别:长度,效率,存储 1.长度 char...

  • 2019-08-09

    今天练习使用MySQL

  • 最近一周计划

    1.准备蓝桥杯竞赛,每天至少抽出一个小时练习算法 2.小组MySQL进度放慢,适当分配时间给算法练习 3.养成早睡...

  • Python day25_mysql数据库

    mysql 数据库 查询练习

  • 2019-08-06

    今天仍然练习MySQL的操作

网友评论

      本文标题:mysql 练习3

      本文链接:https://www.haomeiwen.com/subject/lrwxyftx.html