牛客网-SQL专项练习1
①检索所有比“王华”年龄大的学生姓名、年龄和性别。SQL语句:
解析:
第一步:先找到王华的年龄
SELECT AGE FROM S WHRE SN = "王华";
第二步:将第一步的结果作为条件进行筛选,比他年龄大的人的信息
SELECT SN,AGE,SEX
FROM S
WHRE AGE > (SELECT AGE FROM S WHRE SN = "王华");
知识点:单行子查询
②有一个User用户表,现要删除整张表(指完全删除表数据和表结构),下面正确的MySQL语句是:
A.DELETE TABLE User; B.DROP TABLE User;
C.TRUNCATE TABLE User; D.DELETE FROM User ;
解析:题目中要求是删除整张表(包括表数据和表结构)。B选项符合要求
知识点:本题主要考查DELETE、DROP、TRUNCATE三者的区别:
DELETE:
语法:DELETE FROM 表名 WHERE 筛选条件
TRUNCATE:
语法:TRUNCATE TABLE 表名; #不允许加条件,不加where
DROP:
DROP TABLE 表名称 #删除表数据和结构
DROP DATABASE #用于删除数据库:
三者区别:
数据恢复方面:delete 可以恢复删除的数据,而 truncate 和 drop 不能恢复删除的数据。
执行速度方面:drop > truncate > delete。
删除数据方面:drop 是删除整张表,包含行数据和字段、索引等数据,而 truncate 和 drop 只删除了行数据。
添加条件方面:delete 可以使用 where 表达式添加查询条件,而 truncate 和 drop 不能添加 where 查询条件。
重置自增列方面:在 InnoDB 引擎中,truncate 可以重置自增列,而 delete 不能重置自增列
③比赛结果result表内容如下:
Date Win
2017-07-12 胜
2017-07-12 负
2017-07-15 胜
2017-07-15 负
如果要生成下列结果, sql语句是:
比赛日期 胜 负
2017-07-12 1 1
2017-07-15 1 1
解析:
要显示的是比赛日期、胜、负,将胜或者负统计成得分求和,并按日期进行分组
故SQL语句为:
SELECT DATE AS 比赛日期, SUM(CASE WHEN '胜' then 1 else 0 end) AS 胜,SUM(CASE WHEN '负' then 1 else 0 end) AS 负
FROM result
GROUP BY DATE;
知识点:
1.别名:select 原名 as 别名 from 表名;
2.聚合函数:常用的聚合函数SUM(总和)、MAX(最大值)、MIN(最小值)、AVG(平均值)、COUNT(计数);
3.流程控制函数语法:
case
when 条件1 then 要显示的值1或语句1
when 条件2 then 要显示的值2或语句2
…
else 要显示的值n或语句n
end
4.GROUP BY :将表中的数据分成若干组,需要将SELECT后面的字段名(除了聚合函数)都包含上【select后面的字段,必须是group by后出现的字段】。
④在gameList表中(player_id, event_date)是主键,如何显示每个玩家(player_id)首次登录的设备号(device_id),并同时显示玩家ID(player_id)?

解析:
需要展示每个玩家(player_id)首次登录的设备号(device_id)并同时展示id,则需要通过子查询的方式获得最小的时间,然后按照id进行展示。
第一步:通过子查询的方式找到每个玩家首次登录的设备号,这里将每个玩家按照时间分等级
SELECT * ,
RANK() OVER(
PARTITION BY player_id
ORDER BY event_date
) AS rank_date
FROM gamelist;
这时就会变成:
| player_id | device_id | event_date | games_played | rank_date |
| 111 | 21 | 2020-01-02 | 6 | 1 |
| 111 | 21 | 2020-03-01 | 5 | 2 |
| 212 | 33 | 2020-09-03 | 1 | 1 |
| 322 | 11 | 2020-01-21 | 0 | 1 |
| 322 | 44 | 2020-03-02 | 5 | 2 |
第二步:然后按照id进行展示
SELECT player_id, device_id
FROM(第一步 )t
WHERE t.rank_date=1
结果:
SELECT player_id, device_id
FROM(SELECT * ,rank() over (partition by player_id order by event_date ) as rank_date from gamelist )t
WHERE t.rank_date=1
| player_id | device_id |
| 111 | 21 |
| 212 | 33 |
| 322 | 11 |
知识点:
牛客网-SQL专项练习1的更多相关文章
- MySql面试题、知识汇总、牛客网SQL专题练习
点击名字直接跳转到链接: Linux运维必会的100道MySql面试题之(一) Linux运维必会的100道MySql面试题之(二) Linux运维必会的100道MySql面试题之(三) Linux运 ...
- 牛客网Sql
牛客网Sql: 1.查询最晚入职的员工信息 select * from employees where hire_date =(select max(hire_date) from employee ...
- 牛客网sql刷题解析-完结
查找最晚入职员工的所有信息 解题步骤: 题目:查询最晚入职员工的所有信息 目标:查询员工的所有信息 筛选条件:最晚入职 答案: SELECT *--查询所有信息就用* ...
- Java基础之引用(String,char[],Integer)总结于牛客网的专项练习题
1.String的引用: 下列代码执行后的结果为: public class Test { public static void main(String[] args) { StringBuffer ...
- 牛客网sql练习
一建表语句 /* Navicat MySQL Data Transfer Source Server : test Source Server Version : 50717 Source Host ...
- 牛客网sql实战参考答案(mysql版):16-21
16.统计出当前(titles.to_date='9999-01-01')各个title类型对应的员工当前(salaries.to_date='9999-01-01')薪水对应的平均工资.结果给出ti ...
- 牛客网sql实战参考答案(mysql版):1-15
1.查找最晚入职员工的所有信息,为了减轻入门难度,目前所有的数据里员工入职的日期都不是同一天(sqlite里面的注释为--,mysql为comment) CREATE TABLE `employees ...
- 牛客网数据库SQL实战解析(51-61题)
牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...
- 牛客网数据库SQL实战解析(41-50题)
牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...
- 牛客网数据库SQL实战解析(31-40题)
牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...
随机推荐
- C++学习笔记之编程思想
目录 编程思想 单例(Singleton)模式 观察者(Observer)模式 void*.NULL和nullptr C的类型转换 C++的类型转换 适配器(Adapter)模式 泛型编程的思想 模板 ...
- 音频信号质量的度量标准--MOS得分的由来
早期语音质量的评价方式是凭主观的,人们在打通电话之后通过人耳来感知语音质量的好坏.1996年国际ITU组织在ITU-T P.800和P.830建议书开始制订相关的评测标准:MOS(Mean Opini ...
- [置顶]
linux与windows之间传输文件工具rz上传大文件失败问题解决方案
rz,sz是Linux/Unix同Windows进行ZModem文件传输的命令行工具. windows端需要支持ZModem的telnet/ssh客户端(比如SecureCRT),运行命令rz即是接收 ...
- My97DatePicker设置默认时间
<%@ page language="java" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC ...
- FFmpeg命令行之ffprobe
一.简述 ffprobe是ffmpeg命令行工具中相对简单的,此命令是用来查看媒体文件格式的工具. 二.命令格式 在命令行中输入如下格式的命令: ffprobe [文件名] 三.使用ffprobe查看 ...
- 三维模型3DTile格式轻量化的数据压缩与性能平衡关系分析
三维模型3DTile格式轻量化的数据压缩与性能平衡关系分析 对于三维模型的3DTile格式轻量化处理,数据压缩和性能之间的平衡关系是一个重要的考虑因素.以下是这两者关系的详细分析: 1.数据压缩与加载 ...
- package.json报错"No license field"问题解决
问题描述 warning package.json: No license field 问题原因 package.json中缺少license字段 解决方法 package.json中添加licens ...
- flink scala 从Oracle同步数据到MySql
pom <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> ...
- Oracle 几种行转列的方式 sum+decode sum+case when pivot
原始数据: 方式一: select t_name, sum(decode(t_item, 'item1', t_num, 0)) item1, sum(decode(t_item, 'item2', ...
- 基于SCCB协议的FPGA实现
SCCB协议 1.协议内容 SCCB协议常用于vo系列的摄像头的寄存器配置中,是有IIC协议演变而来.本来,本人接触这个协议也是想配置摄像头用于摄像模块.但是,由于配置寄存器实在是太多,而且需要找的资 ...