热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

查询某一批名字的人mysql_MYSQL之——查询练习题

1、用一条SQL语句查询出chengji表,每门课都大于80分的学生姓名。namekechengfenshu张三语文81张三数学75李四语文76李四数学90王五语文8

1、用一条SQL 语句 查询出`chengji`表,每门课都大于80 分的学生姓名。

name   kecheng   fenshu

张三     语文         81

张三     数学         75

李四     语文         76

李四     数学         90

王五     语文         81

王五     数学         100

王五     英语         90

sql&#xff1a;select distinct name from chengji where name not in (select name from chengji where fenshu<&#61;80 );

sql&#xff1a;select name from chengji group by name having min(fenshu)>80

思路&#xff1a;筛选出小于等于80的分数的名字&#xff0c;过滤掉小于等于80的分数的名字&#xff0c;再对名字进行去重

对名字进行分组&#xff0c;再判断大于80的分数

注&#xff1a;分组前&#xff0c;条件使用where&#xff1b;分组后&#xff0c;条件使用having&#xff1b;having后通常跟聚合函数

2、学生表 如下:

自动编号    学号       姓名    课程编号    课程名称    分数

1             2005001   张三     0001          数学      69

2             2005002   李四     0001          数学      89

3             2005001   张三     0001          数学      69

1)查询出重复的数据&#xff0c;且id为最大或者最小的

sql&#xff1a;select max(id) id,name,kecheng,fenshu from chengji group by fenshu,kecheng,name having count(name)>1

sql&#xff1a;select min(id) id,name,kecheng,fenshu fromchengji group by fenshu,kecheng,name having count(name)>1

2)删除除了自动编号不同, 其他都相同的学生冗余信息。

sql&#xff1a;

3、一个叫 team 的表&#xff0c;里面只有一个字段name, 一共有4 条纪录&#xff0c;分别是a,b,c,d, 对应四个球对&#xff0c;现在四个球对进行比赛&#xff0c;用一条sql 语句显示所有可能的比赛组合.

思路&#xff1a;先把team分成两个表&#xff1b;两表组合&#xff1b;去掉重复的组合

sql&#xff1a;select a.name,b.name from team a,team b where a.name

4、

eb72cb2ba43e496aa47d93d56ebe92df.png

809bdbfcb50489f246520ad3bf22d339.png

f1e43bb86404a32eeaaaf9bbaf162dfe.png

问题&#xff1a;

1)查询张三的2019年生产产品的销售量(使用left join 关键字)

sql&#xff1a;

select

*

from sales

left join deal on sales.S&#61;deal.S

left join production on deal.P&#61;production.P

where Sname&#61;&#39;张三&#39; and Pdate like &#39;2019%&#39;;

2)查询生产日期2020年的一季度各产品的总销量

sql&#xff1a;

select

t2.P,t2.Pname, SUM(Voulume),t2.Pdate

from deal t1

left join production t2 on t1.P&#61;t2.P

where t2.Pdate like &#39;2020%&#39;

GROUP BY t2.P;

3)查询销售量最高的产品的销量(使用group by关键字)

sql&#xff1a;

select

a.P,a.Pname,max(a.sum1)

from

(

select

t1.P,t1.Pname,sum(Voulume) as sum1

from

production t1

left join deal t2 on t1.P&#61;t2.P

group by t1.P

) a;

5、表名&#xff1a;test_tb_grade

图1

9167682bc40753404395d234b36102be.png

图2

e0c09c73472bedd8792271cb1d1c024b.png

将图1转换为图2

sql&#xff1a;

SELECT id,user_name ,

MAX(CASE course WHEN &#39;数学&#39; THEN score ELSE 0 END ) 数学,

MAX(CASE course WHEN &#39;语文&#39; THEN score ELSE 0 END ) 语文,

MAX(CASE course WHEN &#39;英语&#39; THEN score ELSE 0 END ) 英语

FROM test_tb_grade

GROUP BY USER_NAME;

6、表名&#xff1a;ta

图1

7f7ba5e137d431ba6f8c1cc64850fd2e.png

图2

54a34a04338613a03b336d407484f61e.png

对图1表查成图2的结果

sql&#xff1a;select date_format(datas,&#39;%Y-%m-%d&#39;) &#39;日期&#39; from ta

7、查询出近一周/一月/一年的数据

select * from ta where DATEDIFF(now(),datas)<&#61;7;

select * from ta where DATEDIFF(now(),datas)<&#61;30;

select * from ta where DATEDIFF(now(),datas)<&#61;365;

8、请写出一个SQL来查询分数前五5的所有人&#xff1f;

select * from 分数表 order by 分数 desc limit 5;



推荐阅读
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 本文介绍了在MySQL8.0中如何查看性能并解析SQL执行顺序。首先介绍了查询性能工具的开启方法,然后详细解析了SQL执行顺序中的每个步骤,包括from、on、join、where、group by、having、select distinct、union、order by和limit。同时还介绍了虚拟表的概念和生成过程。通过本文的解析,读者可以更好地理解MySQL8.0中的性能查看和SQL执行顺序。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • MySQL外键1对多问题的解决方法及实例
    本文介绍了解决MySQL外键1对多问题的方法,通过准备数据、创建表和设置外键关联等步骤,实现了用户分组和插入数据的功能。详细介绍了数据准备的过程和外键关联的设置,以及插入数据的示例。 ... [详细]
author-avatar
fishandyp
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有