乐趣区

关于sql:SQL-必知必会-50-题1-5

本文已同步至:村雨遥

SQL1 从 Customers 表中检索所有的 ID

形容

现有表 Customers 如下:

cust_id
A
B
C

问题

编写 SQL 语句,从 Customers 表中检索所有的 cust_id。

示例答案

返回 cust_id 列的内容

cust_id
A
B
C

示例

DROP TABLE IF EXISTS `Customers`;

CREATE TABLE IF NOT EXISTS `Customers`(cust_id VARCHAR(255) DEFAULT NULL
);

INSERT `Customers` VALUES ('A'),('B'),('C');

解答

考查最简略的查问语句,因为 Customers 表中仅有 cust_id 一列,所以咱们能够应用以下两种解答形式。

  • 第一种形式,抉择特定列进行输入,这也是咱们在工作中更加举荐应用的一种形式,将须要输入的列名全副形容进去。
SELECT cust_id FROM Customers;
  • 第二种形式,应用 * 对表中所有列进行输入,因为 Customers 表中仅有一列,所以能够应用该形式。但在日常工作中,就算查问后果列中蕴含了数据库表的所有字段,也不要间接应用 *.
SELECT * FROM Customers;

SQL2 检索并列出已订购产品的清单

形容

表 OrderItems 含有非空的列 prod_id 代表商品 id,蕴含了所有已订购的商品(有些已被订购屡次)。

prod_id
a1
a2
a3
a4
a5
a6
a7

问题

编写 SQL 语句,检索并列出所有已订购商品(prod_id)的去重后的清单。

示例

DROP TABLE IF EXISTS `OrderItems`;
CREATE TABLE IF NOT EXISTS `OrderItems`(prod_id VARCHAR(255) NOT NULL COMMENT '商品 id'
);
INSERT `OrderItems` VALUES ('a1'),('a2'),('a3'),('a4'),('a5'),('a6'),('a6')

解答

要对后果去重,能够应用 DISTINCT 关键字。应用时,在后边跟上须要去重的字段即可保障这些去重字段的查问后果不反复。

SELECT DISTINCT prod_id FROM OrderItems;

此外还能够应用 GROUP BY 关键字,改关键字反对在去重的同时,同步返回其余字段的信息。

SELECT prod_id FROM OrderItems GROUP BY prod_id;

SQL3 检索所有列

形容

当初有 Customers 表(表中含有列 cust_id 代表客户 id,cust_name 代表客户姓名)。

cust_id cust_name
a1 andy
a2 ben
a3 tony
a4 tom
a5 an
a6 lee
a7 hex

问题

须要编写 SQL 语句,检索所有列。

示例后果

返回所有列 cust_id 和 cust_name。

cust_id cust_name
a1 andy
a2 ben
a3 tony
a4 tom
a5 an
a6 lee
a7 hex

示例

DROP TABLE IF EXISTS `Customers`;
CREATE TABLE IF NOT EXISTS `Customers`(cust_id VARCHAR(255) NOT NULL COMMENT '客户 id',
    cust_name VARCHAR(255) NOT NULL COMMENT '客户姓名'
);
INSERT `Customers` VALUES ('a1','andy'),('a2','ben'),('a3','tony'),('a4','tom'),('a5','an'),('a6','lee'),('a7','hex');

解答

相似于第一题,最简略的查问语句,只不过相比第一题多了一列,所以同样能够应用两种形式。

  • 应用 * 示意所有列。
SELECT * FROM Customers;
  • 将须要打印出的列具体列出。
SELECT cust_id, cust_name FROM Customers;

SQL4 检索顾客名称并且排序

形容

有表 Customers,cust_id 代表客户 id,cust_name 代表客户姓名。

cust_id cust_name
a1 andy
a2 ben
a3 tony
a4 tom
a5 an
a6 lee
a7 hex

问题

从 Customers 中检索所有的顾客名称(cust_name),并按从 Z 到 A 的程序显示后果。

示例后果

返回客户姓名 cust_name

cust_name
tony
tom
lee
hex
ben
andy
an

示例

DROP TABLE IF EXISTS `Customers`;
CREATE TABLE IF NOT EXISTS `Customers`(cust_id VARCHAR(255) NOT NULL COMMENT '客户 id',
    cust_name VARCHAR(255) NOT NULL COMMENT '客户姓名'
);
INSERT `Customers` VALUES ('a1','andy'),('a2','ben'),('a3','tony'),('a4','tom'),('a5','an'),('a6','lee'),('a7','hex');

解答

要对数据库中的数据进行排序,须要应用关键字 ORDER BY。此外,默认状况下,SQL 中列的后果默认是正序排列的,即理论状况下以下语句执行后果是一样的。

SELECT cust_name FROM Customers;
SELECT cust_name FROM Customers ORDER BY cust_name ASC;

而要对查问后果逆序输入,则须要用到 DESC 关键字,示意逆序输入。

SELECT cust_name FROM Customers ORDER BY cust_name DESC;

SQL5 对顾客 ID 和日期排序

形容

有 Orders 表

cust_id order_num order_date
andy aaaa 2021-01-01 00:00:00
andy bbbb 2021-01-01 12:00:00
bob cccc 2021-01-10 12:00:00
dick dddd 2021-01-11 00:00:00

问题

编写 SQL 语句,从 Orders 表中检索顾客 ID(cust_id)和订单号(order_num),并先按顾客 ID 对后果进行排序,再按订单日期倒序排列。

示例答案

返回 2 列,cust_id 和 order_num

cust_id order_num
andy bbbb
andy aaaa
bob cccc
dick dddd

示例解析

首先依据 cust_id 进行排列,andy 在 bob 和 dick 前,再依据 order_date 进行排列,订单号 bbbb 的订单工夫是 “2021-01-01 12:00:00” 大于订单号 aaaa 的工夫 “2021-01-01 00:00:00”

示例

DROP TABLE IF EXISTS `Orders`;
CREATE TABLE IF NOT EXISTS `Orders` (`cust_id` varchar(255) NOT NULL COMMENT '顾客 ID',
  `order_num` varchar(255) NOT NULL COMMENT '订单号',
  `order_date` timestamp NOT NULL COMMENT '订单工夫'
);
INSERT INTO `Orders` VALUES ('andy','aaaa','2021-01-01 00:00:00'),
('andy','bbbb','2021-01-01 12:00:00'),
('bob','cccc','2021-01-10 12:00:00'),
('dick','dddd','2021-01-11 00:00:00');

解答

要对列进行排序,则须要应用 ORDER BY 关键字,此外就是正序和倒序输入。

  • ASC:正序输入,也是默认输入的状况。
  • DESC:倒序输入。
SELECT cust_id, order_num FROM Orders ORDER BY cust_id, order_date DESC;

致谢

感激牛客网提供的题目列表。

退出移动版