Sql SQL SELECT DISTINCT 语句 SQL WHERE 子句   AND & OR SQL ORDER BY 关键字 SQL SELECT TOP, LIMIT 子句 SQL IN 操作符 SQL BETWEEN 操作符 SQL 别名

在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(distinct)的值。

DISTINCT 关键词用于返回唯一不同的值。

SELECT DISTINCT country FROM Websites;

原表

+----+--------------+---------------------------+-------+---------+
| id | name         | url                       | alexa | country |
+----+--------------+---------------------------+-------+---------+
| 1  | Google       | https://www.google.cm/    | 1     | USA     |
| 2  | 淘宝          | https://www.taobao.com/   | 13    | CN      |
| 3  | 菜鸟教程      | http://www.runoob.com/    | 4689  | CN      |
| 4  | 微博          | http://weibo.com/         | 20    | CN      |
| 5  | Facebook     | https://www.facebook.com/ | 3     | USA     |
+----+--------------+---------------------------+-------+---------+
结果
Sql
SQL SELECT DISTINCT 语句
SQL WHERE 子句
  AND & OR
SQL ORDER BY 关键字
SQL SELECT TOP, LIMIT 子句
SQL IN 操作符
SQL BETWEEN 操作符
SQL 别名

SQL WHERE 子句

WHERE 子句用于提取那些满足指定标准的记录

 

  AND & OR

SQL 语句从 "Websites" 表中选取国家为 "CN" 且alexa排名大于 "50" 的所有网站:SELECT * FROM Websites WHERE country='CN' AND alexa > 50;

  结合 AND & OR

下面的 SQL 语句从 "Websites" 表中选取 alexa 排名大于 "15" 且国家为 "CN" 或 "USA" 的所有网站:SELECT * FROM Websites WHERE alexa > 15 AND (country='CN' OR country='USA');

SQL ORDER BY 关键字

ORDER BY 关键字用于对结果集按照一个列或者多个列进行排序。

ORDER BY 关键字默认按照升序对记录进行排序。如果需要按照降序对记录进行排序,您可以使用 DESC 关键字。

  ORDER BY 多列

下面的 SQL 语句从 "Websites" 表中选取所有网站,并按照 "country" 和 "alexa" 列排序:SELECT * FROM Websites ORDER BY country,alexa;

SQL SELECT TOP, LIMIT 子句

SELECT column_name(s)
FROM table_name
LIMIT number

SQL IN 操作符

 IN 操作符允许您在 WHERE 子句中规定多个值

SELECT * FROM Websites
WHERE name IN ('Google','菜鸟教程');

SQL BETWEEN 操作符

BETWEEN 操作符用于选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期

下面的 SQL 语句选取 name 以介于 'A' 和 'H' 之间字母开始的所有网站:SELECT * FROM Websites WHERE name BETWEEN 'A' AND 'H';

下面的 SQL 语句选取 date 介于 '2016-05-10' 和 '2016-05-14' 之间的所有访问记录:SELECT * FROM access_log WHERE date BETWEEN '2016-05-10' AND '2016-05-14';

SQL 别名

通过使用 SQL,可以为表名称或列名称指定别名。

在下面的情况下,使用别名很有用:

  • 在查询中涉及超过一个表
  • 在查询中使用了函数
  • 列名称很长或者可读性差
  • 需要把两个列或者多个列结合在一起

下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。提示:如果列名称包含空格,要求使用双引号或方括号:

SELECT name AS n, country AS c
FROM Websites;
在下面的 SQL 语句中,我们把三个列(url、alexa 和 country)结合在一起,并创建一个名为 "site_info" 的别名:
注意需要使用CONCAT
SELECT name, CONCAT(url, ', ', alexa, ', ', country) AS site_info
FROM Websites;
下面的 SQL 语句选取 "菜鸟教程" 的所访问记录。我们使用 "Websites" 和 "access_log" 表,并分别为它们指定表别名 "w" 和 "a"(通过使用别名让 SQL 更简短):