• sqlzoo练习题答案



    title: SQL-Learning
    date: 2019-03-12 20:37:21
    tags: SQL

    这是关于在一个SQL学习网站的练习题答案记录:SQL教程

    SQL基础

    由一些简单的查询开始

    这里的默认表格为WORLD表格 。

    name continent area population gdp
    Afghanistan Asia 652230 25500100 20343000000
    Albania Europe 28748 2831741 12960000000
    Algeria Africa 2381741 37100000 188681000000
    Andorra Europe 468 78115 3712000000
    Angola Africa 1246700 20609294 100990000000
    ....

    name:国家名称 continent:大洲 area:面积 population:人口 gdp:国内生产总值


    SQL对大小写不敏感。

    1. 以显示德国德国的人口
    SELECT population 
    FROM world
    WHERE name = 'Germany'
    
    1. 查询面积为5,000,000以上平方公里的国家,对每个国家显示她的名字和人均国内生产总值gdp/population
    SELECT name, gdp/population 
    FROM world
    WHERE area > 5000000
    
    1. 查询“Ireland 爱尔兰”,“Iceland 冰岛”,“Denmark 丹麦”的国家名称和人口
    SELECT name, population 
    FROM world
    WHERE name IN ('Ireland', 'Iceland', 'Denmark');--IN 操作符允许我们在 WHERE 子句中规定多个值
    
    1. 面积为200,000及250,000之间的国家名称和该国面积
    SELECT name, area 
    FROM world
    WHERE area 
    BETWEEN 200000 AND 250000;
    --操作符 BETWEEN ... AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。
    

    SELECT国家名字

    name continent
    Afghanistan Asia
    Albania Europe
    Algeria Africa
    Andorra Europe
    Angola Africa
    ....

    name:国家名称 continent:大洲


    SQL 通配符

    在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。

    SQL 通配符必须与 LIKE 运算符一起使用。

    在 SQL 中,可使用以下通配符:

    通配符 描述
    % 替代一个或多个字符
    _ 仅替代一个字符
    [charlist] 字符列中的任何单一字符
    [^charlist]或者[!charlist] 不在字符列中的任何单一字符

    1. 找出以Y为开首的国家
    SELECT name 
    FROM world
    WHERE name LIKE 'Y%'
    --LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。
    
    1. 找出以Y为结尾的国家
    SELECT name 
    FROM world
    WHERE name LIKE '%Y'
    
    1. 找出包含字母x的所有国家
    SELECT name 
    FROM world
    WHERE name 
    LIKE '%x%'
    
    1. 找出名字以land结尾的所有国家
    SELECT name 
    FROM world
    WHERE name 
    LIKE '%land'
    
    1. 查找以C开头,ia结尾的所有国家
    SELECT name 
    FROM world
    WHERE name 
    LIKE 'C%ia'
    
    1. 找出名字包含双oo的国家
    SELECT name 
    FROM world
    WHERE name 
    LIKE '%oo%'
    
    1. 找出名字包含三个或三个以上a的国家
    SELECT name 
    FROM world
    WHERE name 
    LIKE '%a%a%a%'
    
    1. 找出名字第二个字母为t的国家
    SELECT name 
    FROM world
    WHERE name 
    LIKE '_t%'
    ORDER BY name
    
    1. 找出所有国家,其名字都有两个字母 o,被另外两个字母相隔着
    SELECT name 
    FROM world
    WHERE name 
    LIKE '%o__o%'
    

    10 . 找出名字是4个字母的国家

    SELECT name 
    FROM world
    WHERE name 
    LIKE '____'
    
    1. 找出首都和国家名字相同的国家
    SELECT name
    FROM world
    WHERE name = capital; --可以加空格
    
    1. “Mexico 墨西哥”的首都是”Mexico City”。找出所有国家名字,其首都是国家名字加上”City”。
    SELECT name
    FROM world
    WHERE capital = concat(name,' City');--注意City前面的空格
    
    1. 找出所有首都和其国家名字,而首都要有国家名字中出現。
    SELECT capital,name
    FROM world
    WHERE capital 
    LIKE concat('%',name,'%')
    
    1. 找出所有首都和其国家名字,而首都是国家名字的延伸。
      你愿显示 Mexico City,因它比其国家名字 Mexico 長。
      你不愿显示 Luxembourg,因它的首都和国家名相是相同的。
    SELECT name,capital
    FROM world
    WHERE capital 
    LIKE concat(name,'%')  --注意审题,国家名字的延伸,那么国家名字应该在最前面。
    AND capital != name;--这里也可以用"<>"
    
    1. "Monaco-Ville"是合併國家名字 "Monaco" 和延伸詞"-Ville"

      顯示國家名字,及其延伸詞,如首都是國家名字的延伸

      你可以使用SQL函數 REPLACE 或 MID

      SELECT name,replace(capital, name, '') 
      FROM world 
      WHERE capital 
      LIKE concat(name,'%_')
      /*replace函数定义
      replace(original-string,search-string,replace-string)
      original-string: 被搜索的字符串。可为任意长度。
      search-string: 要搜索并被 replace-string 替换的字符串。该字符串的长度不应超过 255 个字节。如果 search-string 是空字符串,则按原样返回原始字符串。
      replace-string: 该字符串用于替换 search-string。可为任意长度。如果 replacement-string 是空字符串,则删除出现的所有 search-string。
      说明
      用字符串表达式3替换字符串表达式1中出现的所有字符串表达式2的匹配项。返回新的字符串。
      如果有某个参数为 NULL,此函数返回 NULL。
      */
      

    SQLZOO练习题之SELECT from WORLD Tutorial/zh

    查询世界


    name continent area population gdp
    Afghanistan Asia 652230 25500100 20343000000
    Albania Europe 28748 2831741 12960000000
    Algeria Africa 2381741 37100000 188681000000
    Andorra Europe 468 78115 3712000000
    Angola Africa 1246700 20609294 100990000000
    ...

    name:国家名称 continent:大洲 area:面积 population:人口 gdp:国内生产总值

    **表格说明 **


    1. *查询大于2亿人口的国家。
    SELECT name 
    FROM world
    WHERE population>200000000;
    
    1. 查询大于2亿人口的国家,及国内生产总值
    SELECT name,gdp/population
    FROM world
    WHERE population > 200000000;
    
    1. 查询在South America南美洲的国际爱和以百万为单位的人口數
    SELECT name,population / 1000000
    FROM world
    WHERE continent = 'South America';--别忘记单引号,代表字符串
    
    1. 查询法国,德国,意大利(France, Germany, Italy)的国家名称和人口
    SELECT name,population
    FROM world
    WHERE name in ('France', 'Germany', 'Italy')--别忘记单引号,代表字符串
    
    1. 查询包含单词“United”的国家
    SELECT name
    FROM world
    WHERE name
    LIKE '%United%';
    
    1. 查询大国(面积大于300万平方公里或者人口大于2.5亿)的名字,面积,人口
    SELECT name,population,area
    FROM world
    WHERE area > 3000000 
    OR population > 250000000;
    
    1. 美国,印度,中国(USA, India, China)是人口又大,同时面积又大的國家。排除这些国家。

      顯示以人口或面积为大国的國家,但不能同时面积大且人口多的国家名称,人口,面积。

    SELECT name,population,area
    FROM world
    WHERE (area > 3000000 AND population < 250000000)
    OR (area < 3000000 AND population > 250000000);
    
    1. 查询并显示南美洲国家以百万计人口和10亿计gdp(保留小数点2位)。
    SELECT name,ROUND(population/1000000,2),ROUND(gdp/1000000000,2)
    FROM world
    WHERE continent = 'South America';
    /*ROUND 函数用于把数值字段舍入为指定的小数位数。
    SELECT ROUND(column_name,要保留的位数) FROM table_name*/
    

    ROUND() 函数

    1. 查询万亿元国内生产总值国家的人均国内生产总值,四捨五入到最近的$ 1000。
    SELECT name,ROUND(gdp/population,-3)
    FROM world
    WHERE gdp > 1000000000000;
    

    继续使用round函数。因为留一位小数1,不留小数是0,-1就好比153不留3,直接四舍五入150,同样-2就是153,不留53,直接四舍五入200.

  • 相关阅读:
    MATLAB数据处理快速学习教程
    dev -c++ 快捷键
    SQL 通配符
    如何利用SQL语句求日期的时间差值,并汇总网上的一些信息
    matlab使用常犯的错误
    matlab中将矩阵按照行打乱顺序的一个例子
    我所认识的PCA算法的princomp函数与经历 (基于matlab)
    java 读取本地的json文件
    Oracle数据库——SQL基本查询
    Oracle数据库——表的创建与管理
  • 原文地址:https://www.cnblogs.com/sunshinewang/p/10520017.html
Copyright © 2020-2023  润新知