LeetCode MySQL 刷题条记 (一) 您所在的位置:网站首页 es6面试题目 LeetCode MySQL 刷题条记 (一)

LeetCode MySQL 刷题条记 (一)

#LeetCode MySQL 刷题条记 (一)| 来源: 网络整理| 查看: 265

「4月日新计划更文活动」 题目: 595. 大的国家 +-------------+---------+ | Column Name | Type | +-------------+---------+ | name | varchar | | continent | varchar | | area | int | | population | int | | gdp | int | +-------------+---------+ 复制代码 需求

name 是这张表的主键。 这张表的每一行提供:国家名称、所属大陆、面积、人口和 GDP 值。 如果一个国家满足下述两个条件之一,则认为该国是 大国 : 面积至少为 300 万平方公里(即,3000000 km2),或者 人口至少为 2500 万(即 25000000) 编写一个 SQL 查询以报告 大国 的国家名称、人口和面积。 按 任意顺序 返回结果表。 查询结果格式如下例所示。

解析 # Write your MySQL query statement below select name ,population,area from world where area >='3000000' or population >='25000000' 复制代码 题目: 1757. 可回收且低脂的产品 +-------------+---------+ | Column Name | Type | +-------------+---------+ | product_id | int | | low_fats | enum | | recyclable | enum | +-------------+---------+ product_id 是这个表的主键。 low_fats 是枚举类型,取值为以下两种 ('Y', 'N'),其中 'Y' 表示该产品是低脂产品,'N' 表示不是低脂产品。 recyclable 是枚举类型,取值为以下两种 ('Y', 'N'),其中 'Y' 表示该产品可回收,而 'N' 表示不可回收。 复制代码 需求

写出 SQL 语句,查找既是低脂又是可回收的产品编号。 返回结果 无顺序要求 。

解析 # Write your MySQL query statement below select product_id from products where low_fats ='y' and recyclable = 'y' 复制代码 题目: 584. 寻找用户推荐人 +------+------+-----------+ | id | name | referee_id| +------+------+-----------+ | 1 | Will | NULL | | 2 | Jane | NULL | | 3 | Alex | 2 | | 4 | Bill | NULL | | 5 | Zack | 1 | | 6 | Mark | 2 | +------+------+-----------+ 里面保存了所有客户信息和他们的推荐人 复制代码 需求

写一个查询语句,返回一个客户列表,列表中客户的推荐人的编号都 **不是 **2。

解析 # Write your MySQL query statement below select name from customer where id not in (select id from customer where referee_id= '2') 复制代码 题目:183. 从不订购的客户 +----+-------+ | Id | Name | +----+-------+ | 1 | Joe | | 2 | Henry | | 3 | Sam | | 4 | Max | +----+-------+ 复制代码 +----+------------+ | Id | CustomerId | +----+------------+ | 1 | 3 | | 2 | 1 | +----+------------+ 某网站包含两个表,Customers 表和 Orders 表。 复制代码 需求:

编写一个 SQL 查询,找出所有从不订购任何东西的客户。

解析 # Write your MySQL query statement below select name as 'Customers' from Customers where id not in (select CustomerId from orders) 复制代码 知识点 where 组合子句(数据过滤)

在mysql语句中可以使用多种组合过滤的方式,其实包含and 、or 、in、not 然而在上述题目中用到这些知识点

and 定义:AND指示DBMS只返回满足所有给定条件的行 语句格式: select 列名 from 表 where 条件(eg : key1=a and key2=b ) ; or 定义:OR操作符告诉DBMS匹配任一条件而不是同时匹配两个条件 语句格式:select 列名 from 表 where 条件(eg : key1=a or key2=b ) ; in 定义:IN操作符用来指定条件范围,范围中的每个条件都可以进行匹配 语句格式:select 列名 from 表 where 条件(eg : key1 in(a,b) ) ; not WHERE子句中用来否定后跟条件的关键字 语句格式:select 列名 from 表 where 条件(eg : key1 not in(a,b) ) ;

在这些操作符中,他们也是有优先级排列的,优先级:() > AND > OR,在sql语句中,SQL(像多数语言一样)在处理OR操作符前,优先处理AND操作符

别名使用 别名在字段中使用as 栗子: select concat(vend_name,'(',vend_country,')') AS vend_title from 表名 order by 列名;


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有