【SQL入门到深入】自学SQL网习题题解(非会员篇)


前言

        最近在刷SQL的题目,顺便记录一下我的一些解题思路,同时希望能给有需要的小伙伴提供一些帮助。


一、网站在哪?

         http://www.xuesql.cn/

二、话不多说,直接上干货!

SQL Lesson 0: 让我给SQL做个自我介绍

  1. 这是第一题,请你先将左侧的输入框里的内容清空,然后请输入下面的SQL,您将看到所有电影标题:
    SELECT TITLE FROM MOVIES;
  2. 请输入如下SQL你将看到4条电影(切记先清空数据框且出错要耐心比对):
    SELECT TITLE,DIRECTOR FROM MOVIES WHERE ID <5;
  3. 输入如下SQL你将看到电影总条数:
    SELECT COUNT(*)FROM MOVIES;
  4. SQL可以直接做计算,下面的SQL计算1+1的和,请输入:
    SELECT 1+1;

SQL Lesson 1: SELECT 查询 101

  1.  找到所有电影的名称
    SELECT TITLE FROM MOVIES;
  2. 找到所有电影的导演 
    SELECT DIRECTOR FROM MOVIES;
  3. 找到所有电影的名称和导演
    SELECT TITLE , DIRECTOR FROM MOVIES;
  4. 找到所有电影的名称和上映年份
    SELECT TITLE , YEAR FROM MOVIES;
  5. 找到所有电影的所有信息
    SELECT * FROM MOVIES;
  6. 找到所有电影的名称,Id和播放时长
    SELECT TITLE,ID,LENGTH_MINUTES FROM MOVIES;

 SQL Lesson 2: 条件查询 (constraints) (Pt. 1)

  1. 找到id为6的电影
    SELECT * FROM MOVIES WHERE ID = 6;
  2. 找到在2000-2010年间year上映的电影
    SELECT * FROM MOVIES 
    WHERE YEAR BETWEEN 2000 AND 2010;
  3. 找到不是在2000-2010年间year上映的电影

    SELECT * FROM MOVIES 
    WHERE YEAR NOT BETWEEN 2000 AND 2010;
  4. 找到头5部电影

    SELECT * FROM MOVIES 
    WHERE ID<=5;
  5. 找到2010(含)年之后的电影里片长小于两个小时的片子

    SELECT * FROM MOVIES 
    WHERE YEAR>=2010 AND LENGTH_MINUTES<120;

 SQL Lesson 3: 条件查询(constraints) (Pt. 2)

  1. 找到所有Toy Story系列电影(注:LIKE是模糊查询,没有用通配符时,等价于"=";也就是说,如果用了通配符,就不应该用"="进行查询;%是通配符,代表匹配0个以上的字符,而代表1个字符则用"-")
    SELECT * FROM MOVIES 
    WHERE TITLE LIKE "TOY STORY%";
  2. 找到所有John Lasseter导演的电影(注:字符串应该用英文的双引号" "括起来,否则会被认为是某个属性的名字)
    SELECT * FROM MOVIES 
    WHERE DIRECTOR LIKE "JOHN LASSETER";
  3. 找到所有不是John Lasseter导演的电影
    SELECT * FROM MOVIES 
    WHERE DIRECTOR NOT LIKE "JOHN LASSETER";
  4. 找到所有电影名为 "WALL-" 开头的电影
    SELECT * FROM MOVIES 
    WHERE TITLE LIKE "WALL%";
  5. 有一部98年电影中文名《虫虫危机》请给我找出来(注:**************************)
    SELECT * FROM MOVIES
    WHERE YEAR = "1998" AND TITLE LIKE "A BUG%";

 SQL Lesson 4: 查询结果Filtering过滤 和 sorting排序

  1. 按导演名排重列出所有电影(只显示导演),并按导演名正序排列(注:下面的代码可能在敲第一行的时候就通过了,但是毕竟是要正序排列,DISTINCT只是起到限定唯一返回值的作用。)
    SELECT DISTINCT DIRECTOR FROM MOVIES
    ORDER BY DIRECTOR ASC;
  2. 列出按上映年份最新上线的4部电影(注:下面的4后面还可以加上"OFFSET 0")
    SELECT * FROM MOVIES 
    ORDER BY YEAR DESC
    LIMIT 4;
  3. 按电影名字母序升序排列,列出前5部电影
    SELECT * FROM MOVIES 
    ORDER BY TITLE ASC
    LIMIT 5;
  4. 按电影名字母序升序排列,列出上一题之后的5部电影(注:OFFSET用于指定从哪一行开始,但是不包括这一行)
    SELECT * FROM MOVIES 
    ORDER BY TITLE ASC
    LIMIT 5 OFFSET 5;
  5. 如果按片长排列,John Lasseter导演导过片长第3长的电影是哪部,列出名字即可(注:从第二个开始,但是不包括第二个)
    SELECT TITLE FROM MOVIES 
    WHERE DIRECTOR LIKE "JOHN LASSETER"
    ORDER BY LENGTH_MINUTES DESC
    LIMIT 1 OFFSET 2;

总结

提示:这里对文章进行总结:

例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值