Sql
SQL SELECT DISTINCT 语句
在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(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 |
+----+--------------+---------------------------+-------+---------+
结果
![](https://img2018.cnblogs.com/blog/1606759/201903/1606759-20190313112343110-2025750400.png)
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 列的别名。提示:如果列名称包含空格,要求使用双引号或方括号:
FROM Websites;
FROM Websites;