SQL SELECT TOP, LIMIT, ROWNUM 子句

这几个语句都是用于筛选出特定条数的数据(一般大型数据库常用)

  • TOP--(Sql Server )
    SQL Server / MS Access 语法:SELECT TOP number|percent column_name(s) FROM table_name;
    实例SELECT * FROM Persons LIMIT 5;

变相返回后 N 行:

--前5行
select top 5 * from table

--后5行
select top 5 * from table order by id desc  --desc 表示降序排列 asc 表示升序
  • limit--(mysql)
    MySQL 语法SELECT column_name(s) FROM table_name LIMIT number;

  • rownum--(oracle)
    Oracle 语法SELECT column_name(s) FROM table_name WHERE ROWNUM <= number;
    实例SELECT * FROM Persons WHERE ROWNUM <=5;

SQL LIKE 操作符

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。
like , not like :复杂过滤,模糊匹配 like 函数

SQL LIKE 语法
SELECT column_name(s) FROM table_name WHERE column_name LIKE pattern;

通配符

符号描述
%替代 0 个或多个字符
_替代一个字符
[charlist]字符列中的任何单一字符
[^charlist]或[!charlist]不在字符列中的任何单一字符

下面的 SQL 语句选取 name 以 “G”、“F” 或 “s” 开始的所有网站:
实例
SELECT * FROM Websites WHERE name REGEXP '^[GFs]';
下面的 SQL 语句选取 name 以 A 到 H 字母开头的网站:
实例
SELECT * FROM Websites WHERE name REGEXP '^[A-H]';
下面的 SQL 语句选取 name 不以 A 到 H 字母开头的网站:
实例
SELECT * FROM Websites WHERE name REGEXP '^[^A-H]';

pattern详情:

语句描述
‘%a’以a结尾的数据
‘a%’以a开头的数据
‘%a%’含有a的数据
a三位且中间字母是a的
‘_a’两位且结尾字母是a的
‘a_’两位且开头字母是a的

% 代表任意多个字符(可以是 0 个),_ 代表一个字符,__ 代表两个字符。

SQL IN 操作符

IN 操作符允许在 WHERE 子句中规定多个值。
SQL IN 语法:
SELECT column_name(s) FROM table_name WHERE column_name IN (value1,value2,...);

//例:选取 name 为 "Google""菜鸟教程" 的所有网站:
SELECT * FROM Websites
WHERE name IN ('Google','菜鸟教程');

IN 与 = 的异同
相同点:均在WHERE中使用作为筛选条件之一、均是等于的含义
不同点:IN可以规定多个值,等于规定一个值
IN:
SELECT column_name(s) FROM table_name WHERE column_name IN (value1,value2,...);
=:
SELECT column_name(s) FROM table_name WHERE column_name=value1;

in 与 = 的转换
select * from Websites where name in ('Google','菜鸟教程');
可以转换成 = 的表达:
select * from Websites where name='Google' or name='菜鸟教程';

SQL BETWEEN 操作符

BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
SQL BETWEEN 语法
SELECT column_name(s) FROM table_name WHERE column_name BETWEEN value1 AND value2;

NOT BETWEEN
如需显示不在范围内的属性,使用 NOT BETWEEN

例:

  • 带有 IN 的 BETWEEN 操作符实例
    下面的 SQL 语句选取 alexa 介于 1 和 20 之间但 country 不为 USA 和 IND 的所有网站:
    SELECT * FROM Websites
    WHERE (alexa BETWEEN 1 AND 20)
    AND country NOT IN ('USA', 'IND');
  • 带有文本值的 NOT BETWEEN 操作符实例
    下面的 SQL 语句选取 name 不介于 ‘A’ 和 ‘H’ 之间字母开始的所有网站:
    实例
    SELECT * FROM Websites
    WHERE name NOT BETWEEN 'A' AND 'H';
  • 带有日期值的 BETWEEN 操作符实例
    下面的 SQL 语句选取 date 介于 ‘2016-05-10’ 和 ‘2016-05-14’ 之间的所有访问记录:
    实例
    SELECT * FROM access_log
    WHERE date BETWEEN '2016-05-10' AND '2016-05-14';

在不同的数据库中,BETWEEN 操作符会产生不同的结果
在某些数据库中,BETWEEN 选取介于两个值之间但不包括两个测试值的字段。
在某些数据库中,BETWEEN 选取介于两个值之间且包括两个测试值的字段。(在 MySQL 中)
在某些数据库中,BETWEEN 选取介于两个值之间且包括第一个测试值但不包括最后一个测试值的字段。

SQL 别名

通过使用 SQL,可以为表名称或列名称指定别名。
基本上,创建别名是为了让列名称的可读性更强。
使用别名的情景:
1.在查询中涉及超过一个表
2.在查询中使用了函数
3.列名称很长或者可读性差
4.需要把两个列或者多个列结合在一起

  • 列的 SQL 别名语法
    SELECT column_name AS alias_name FROM table_name;
    例:
    (1)用SQL 语句指定两个别名,一个是 name 列的别名,一个是 country 列的别名。(如果列名称包含空格,要求使用双引号或方括号)
    SELECT name AS n, country AS c FROM Websites;
    (2)选出名字,并把三个列(url、alexa 和 country)结合在一起,并创建一个名为 “site_info” 的别名:(即结果为一个新的表格,有两个列,一个列名为name,另一个列名为site_info,site_info里面有原先表格里面三个列的内容:url、alexa 和 country)
    SELECT name, CONCAT(url, ', ', alexa, ', ', country) AS site_info FROM Websites;
  • 表的 SQL 别名语法
    SELECT column_name(s) FROM table_name AS alias_name;
    例:
    使用 “Websites” 和 “access_log” 表,并分别为它们指定表别名 “w” 和 “a”(通过使用别名让 SQL 更简短):
    SELECT w.name, w.url, a.count, a.date
    FROM Websites AS w, access_log AS a
    WHERE a.site_id=w.id and w.name="菜鸟教程";
    (把"Websites" 和 “access_log” 表分别指定表别名为 “w” 和 “a”,并筛选出a表中site_id等于w表中的id及w表中name为“菜鸟教程”的 w表中的name、url属性和a表中的count、date属性)

「你被安稳地爱着呢,应该有做任何事的勇气」

更多推荐

数据库学习笔记二--复杂语句(1)