2.1 SELECT语句
SELECT语句的用途是从一个或多个表中检索信息。
关键字(keyword):
作为SQL组成部分的保留字。关键字不能作为表或列的名字。
2.2 检索单个列
例如:输入
SELECT prod_name FROM Products;
上述语句利用SELECT语句从Products表中检索一个名为prod_name的列,FROM关键字指出从哪个表中检索数据。
输出:

提示:
1.多条SQL语句必须以分号分隔;
2.SQL语句不区分大小写;
3.SQL语句可以写成长长的一行,也可以分写在多行;
2.3 检索多个列
想要从一个表中检索多个列,仍然使用相同的SELECT语句,唯一的不同是必须在SELECT关键字后给出多个列名,列名之间必须以逗号分隔。
提示:
选择多个列时必须在列名之间加上逗号,但最后一个列名不加,否则将出现错误;
例如:输入
SELECT prod_id, prod_name, prod_price FROM Products;
输出:

2.4 检索所有列
除了指定所需的列外,SELECT语句还可以使用通配符(*)检索所有的列而不必逐个列出它们。
提示:
1.除非你确实需要表中的每一列,否则最好别使用通配符(*),检索不需要的列通常会降低检索和应用程序的性能;
2.使用通配符(*)时,能检索出名字未知的列;
例如:输入
SELECT * FROM Products;
输出:

2.5 检索不同的值
SELECT语句将返回所有匹配的行,但有时你不希望每个值每次都出现。
例如:输入
SELECT vend_id FROM Products;
输出:

SELECT所返回的行中存在相同的值,那么如何只检索出不同的值呢?
解决办法就是使用DISTINCT关键字,它指示数据库只返回不同的值。
例如:输入
SELECT DISTINCT vend_id FROM Products;
输出:

提示:
DISTINCT关键字作用于所有的列,不仅仅是跟在其后的那一列;
2.6 限制结果
SELECT语句返回指定表中所有匹配的行,但如果你只想返回第一行或一定数量的行时该怎么办呢?
遗憾的是,各种数据库中的这一SQL实现并不相同。
1.在SQL Server和Access中使用SELECT时,可以使用TOP关键字来限制最多返回多少行
例如:
SELECT TOP 5 prod_name FROM Products;
2.如果你使用的是DB2时
例如:
SELECT prod_name FROM Products FETCH FIRST 5 ROWS ONLY;
3.如果你使用的是Oracle,需要基于ROWNUM(行计数器)来计算行
例如:
SELECT prod_name FROM Products WHERE ROWNUM <=5;
4.如果你使用 MySQL、MariaDB、PostgreSQL或者 SQLite,需要使用 LIMIT 子句
例如:
SELECT prod_name FROM Products LIMIT 5;
还可以指定从哪儿开始以及检索的行数
例如:
SELECT prod_name FROM Products LIMIT 5 OFFSET 5;
第一个数字是指从哪儿开始,第二个数字是检索的行数
提示:
1.第一个被检索的行是第0行,因此LIMIT 1 OFFSET 1 会检索第2行而不是第1行
2.MYSQL和MariaDB支持简化版的LIMIT,即LIMIT 3 OFFSET 4 = LIMIT 4,3。逗号之前的值对应OFFSET,逗号之后的值对应LIMIT
2.7 使用注释
SQL语句是由DBMS处理的指令,但如果你希望包括不进行处理和执行的文本时,就可以使用注释。
很多DBMS都支持各种形式的注释语法。
1.行内注释:
SELECT prod_name -- 这是一条注释
FROM Products;
2.另一种形式的行内注释:
# 这是一条注释
SELECT prod_name FROM Products;
3.多行注释:
/* SELECT prod_name, vend_id
FROM Products; */
SELECT prod_name FROM Products;
小结
这一课学习了如何使用 SQL的 SELECT 语句来检索单个表列、多个表列 以及所有表列。同时也学习了如何返回不同的值,如何注释代码。
本文详细介绍了SQL中SELECT语句的使用方法,包括检索单个列、多个列及所有列,检索不同值,限制结果集及使用注释等实用技巧。

被折叠的 条评论
为什么被折叠?



