sqlzoo练习题答案


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

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

SQL基础

由一些简单的查询开始

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

namecontinentareapopulationgdp
AfghanistanAsia6522302550010020343000000
AlbaniaEurope28748283174112960000000
AlgeriaAfrica238174137100000188681000000
AndorraEurope468781153712000000
AngolaAfrica124670020609294100990000000
....

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国家名字

namecontinent
AfghanistanAsia
AlbaniaEurope
AlgeriaAfrica
AndorraEurope
AngolaAfrica
....

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

查询世界


namecontinentareapopulationgdp
AfghanistanAsia6522302550010020343000000
AlbaniaEurope28748283174112960000000
AlgeriaAfrica238174137100000188681000000
AndorraEurope468781153712000000
AngolaAfrica124670020609294100990000000
...

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.

转载于:https://www.cnblogs.com/sunshinewang/p/10520017.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值