第2课、检索数据
SELECT:查询
从一个或多个表中检索信息。
|-------------|
| 1)检索单个列 |
需求:从 Products 表中查询所有行的产品名称。
sql
SElECT prod_name
FROM Products;
输出结果:
|-------------|
| 2)检索多个列 |
需求:从 Products 表中查询所有行的产品ID、名称和价格。
sql
SELECT prod_id,prod_name,prod_price
FROM Products;
输出结果:
|-------------|
| 3)检索所有列 |
需求:从 Products 表中查询所有行的所有列。
sql
SELECT * FROM Products;
输出结果:
|--------------|
| 4)检索不同的值 |
需求:检索 Products 表中所有产品供应商的 ID。
sql
SELECT vend_id
From Products;
输出结果:
DISTINCT:过滤重复的记录
DISTINCT:过滤掉多余的重复记录只保留一条
需求:检索 Products 表中所有产品供应商的 ID,并不重复出现相同的值。
sql
SELECT DISTINCT vend_id
From Products;
输出结果:
如果使用如下命令,则 DISTINCT 对 vend_id 和 prod_price 组合有两种不同的结果,并同时一起输出:
sql
SELECT DISTINCT vend_id, prod_price
From Products;
/*
(个人思考)
如果把语法中的 vend_id 和 prod_price 的位置互换一下:
SELECT DISTINCT prod_price,vend_id
From Products;
1.从输出结果来看,就会发现:
- DISTINCT 后的第一列会默认升序排序
- 当 某个列检索得出不同值的个数是所有列中最多的,以该列输出不重复值为准。
- 而其他列值依旧存在重复值。
2.尝试执行其他代码,自己可以研究一下结果:
SELECT DISTINCT vend_id,prod_name, prod_price
From Products;
SELECT DISTINCT vend_id, prod_price
From Products
ORDER BY prod_price ASC;
(DISTINCT vend_id 列排序失效,按 prod_price 升序排序)
*/
输出结果:
|------------|
| 5)限制结果 |
TOP:最多返回的行数
限制最多返回多少行。
需求:只检索前5行数据。
- SQL 语句:
sql
SELECT TOP 5 prod_name
FROM Products;
- 如果使用 DB2:
sql
SELECT prod_name
FROM Products
FETCH FIRST 5 ROWS ONLY;
- 如果使用 Oracle:
sql
SELECT prod_name
FROM Products
Where ROWNUM <=5;
- 如果使用 MySQL、MariaDB、PostgreSQL 或者 SQLite:
sql
SELECT prod_name
FROM Products
LIMIT 5;
SQL
SELECT prod_name
FROM Products
LIMIT 5 OFFSET 5;
-- 从第5行起的5行数据
输出结果:
总结
SELECT:查询
SELECT 列
FROM 表
DISTINCT:过滤掉多余的重复记录只保留一条
SELECT DISTINCT 列
From 表;
TOP:限制最多返回多少行
SELECT TOP 行数 列
FROM 表;