前言
最近在刷SQL的题目,顺便记录一下我的一些解题思路,同时希望能给有需要的小伙伴提供一些帮助。
一、网站在哪?
二、话不多说,直接上干货!
SQL Lesson 0: 让我给SQL做个自我介绍
- 这是第一题,请你先将左侧的输入框里的内容清空,然后请输入下面的SQL,您将看到所有电影标题:
SELECT TITLE FROM MOVIES;
- 请输入如下SQL你将看到4条电影(切记先清空数据框且出错要耐心比对):
SELECT TITLE,DIRECTOR FROM MOVIES WHERE ID <5;
- 输入如下SQL你将看到电影总条数:
SELECT COUNT(*)FROM MOVIES;
- SQL可以直接做计算,下面的SQL计算1+1的和,请输入:
SELECT 1+1;
SQL Lesson 1: SELECT 查询 101
- 找到所有电影的名称
SELECT TITLE FROM MOVIES;
- 找到所有电影的导演
SELECT DIRECTOR FROM MOVIES;
- 找到所有电影的名称和导演
SELECT TITLE , DIRECTOR FROM MOVIES;
- 找到所有电影的名称和上映年份
SELECT TITLE , YEAR FROM MOVIES;
- 找到所有电影的所有信息
SELECT * FROM MOVIES;
- 找到所有电影的名称,Id和播放时长
SELECT TITLE,ID,LENGTH_MINUTES FROM MOVIES;
SQL Lesson 2: 条件查询 (constraints) (Pt. 1)
- 找到
id
为6的电影SELECT * FROM MOVIES WHERE ID = 6;
- 找到在2000-2010年间
year
上映的电影SELECT * FROM MOVIES WHERE YEAR BETWEEN 2000 AND 2010;
-
找到不是在2000-2010年间
year
上映的电影SELECT * FROM MOVIES WHERE YEAR NOT BETWEEN 2000 AND 2010;
-
找到头5部电影
SELECT * FROM MOVIES WHERE ID<=5;
-
找到2010(含)年之后的电影里片长小于两个小时的片子
SELECT * FROM MOVIES WHERE YEAR>=2010 AND LENGTH_MINUTES<120;
SQL Lesson 3: 条件查询(constraints) (Pt. 2)
- 找到所有
Toy Story
系列电影(注:LIKE是模糊查询,没有用通配符时,等价于"=";也就是说,如果用了通配符,就不应该用"="进行查询;%是通配符,代表匹配0个以上的字符,而代表1个字符则用"-")SELECT * FROM MOVIES WHERE TITLE LIKE "TOY STORY%";
- 找到所有
John Lasseter
导演的电影(注:字符串应该用英文的双引号" "括起来,否则会被认为是某个属性的名字)SELECT * FROM MOVIES WHERE DIRECTOR LIKE "JOHN LASSETER";
- 找到所有不是
John Lasseter
导演的电影SELECT * FROM MOVIES WHERE DIRECTOR NOT LIKE "JOHN LASSETER";
- 找到所有电影名为
"WALL-"
开头的电影SELECT * FROM MOVIES WHERE TITLE LIKE "WALL%";
- 有一部98年电影中文名《虫虫危机》请给我找出来(注:**************************)
SELECT * FROM MOVIES WHERE YEAR = "1998" AND TITLE LIKE "A BUG%";
SQL Lesson 4: 查询结果Filtering过滤 和 sorting排序
- 按导演名
排重
列出所有电影(只显示导演),并按导演名正序排列(注:下面的代码可能在敲第一行的时候就通过了,但是毕竟是要正序排列,DISTINCT只是起到限定唯一返回值的作用。)SELECT DISTINCT DIRECTOR FROM MOVIES ORDER BY DIRECTOR ASC;
- 列出按上映年份
最新
上线的4部电影(注:下面的4后面还可以加上"OFFSET 0")SELECT * FROM MOVIES ORDER BY YEAR DESC LIMIT 4;
- 按电影名字母序
升序
排列,列出前5部电影SELECT * FROM MOVIES ORDER BY TITLE ASC LIMIT 5;
- 按电影名字母序升序排列,列出上一题
之后
的5部电影(注:OFFSET用于指定从哪一行开始,但是不包括这一行)SELECT * FROM MOVIES ORDER BY TITLE ASC LIMIT 5 OFFSET 5;
- 如果按片长排列,John Lasseter导演导过片长第3长的电影是哪部,列出名字即可(注:从第二个开始,但是不包括第二个)
SELECT TITLE FROM MOVIES WHERE DIRECTOR LIKE "JOHN LASSETER" ORDER BY LENGTH_MINUTES DESC LIMIT 1 OFFSET 2;
总结
提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。