SQL复习——高级语法

SQL SELECT TOP 字句

SELECT TOP 字句用于规定要返回的记录数目,对于拥有数千条记录的大型表来说是非常有用的。

SELECT TOP number/percent column_name(s)
FROM table_name;

SQL LIKE操作符

LIKE操作符用于在WHERE字句中搜索列中的指定模式

SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern;
#实例
SELECT * FROM Websites
WHERE name LIKE 'G%';
SELECT * FROM Websites
WHERE name NOT LIKE '%oo%';

SQL 通配符

通配符可用于替代字符串中的任何其他字符

通配符描述
%替代零个或者多个字符
_替代一个字符
[charlist]字符列中的任何单一字符
[^charlist]不在字符列中的任何单一字符
SELECT * FROM Websites
WHERE url LIKE 'https%';
SELECT * FROM Websites
WHERE url LIKE '%oo%';
SELECT * FROM Websites
WHERE name LIKE '_oogle'; 

SQL IN 操作符

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

SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2,...);
SELECT * FROM Websites
WHERE name IN ('Google','菜鸟教程');

SQL BETWEEN 操作符

BETWEEN 操作符用于选取介于两个值之间的数据范围内的值

SELECT column_name(s)
FROM table_name
WHERE column_name BETWEEN value1 AND value2;
SELECT * FROM Websites
WHERE alexa BETWEEN 1 AND 20;
SELECT * FROM Websites
WHERE alexa NOT BETWEEN 1 AND 20;
#带有IN的BETWEEN操作符实例
SELECT * FROM Websites
WHERE (alexa BETWEEN 1 AND 20)
AND country NOT IN ('USA','IND');
#带有文本值的BETWEEN 操作符实例
SELECT * FROM Websites
WHERE name BETWEEN  'A' AND 'H';
#带有日期值的BETWEEN操作符实例
SELECT * FROM access_log
WHERE date BETWEEN '2016-05-10' AND ‘2016-05-14’

SQL 别名

可以为表明称或者列名称指定别名,基本上创建别名是为了让列的名称更加具有可读性。

SELECT column_name AS alias_name
FROM table_name;
SELECT column_name(s)
FROM table_name AS alias_name;
SELECT name AS n, country AS c
FROM Websites;
#将三个列结合在一起,并创建一个新的别名
SELCT name,CONCAT(url,','alexa,',',country) AS site_info
FROM Websites;
#通过使用别名让语句更简短一些
SELECT w.name,w.url,a.count,a.date
FROM Websites AS w,access_log AS a
WHERE w.id=a.site_id and w.name='菜鸟教程';

SQL 连接(JOIN)

用于将两个或多个表的行结合起来,基于这些表之间的共同字段。最常见的JOIN类型:SQL INNER JOIN(简单的JOIN) 从多个表中返回满足条件的所有行。

SELECT Websites.id,Websites.name,access_log.count,access_log.date
FROM Websites
INNER JOIN access_log
ON Websites.id=access_log.site_id;

SQL INNER JOIN 关键字

INNER JOIN 关键字在表中存在至少一个匹配时返回行

SELECT column_name(s)
FROM table1
INNER JOIN table2
ON table1.column_name=table2.column_name;

在使用join时,on和where条件的区别如下:
1.on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。
2.where条件是在临时表生成好之后,再对临时表进行过滤、这是已经没有left join的含义(必须返回左边表的记录了),条件不为真的就全部过滤掉。

SQL LEFT JOIN 关键字

LEFT JOIN 关键字从左表返回所有行,即使右表中没有匹配。如果右表中没有匹配,则结果为NULL。

SELECT column_name(s)
FROM table1
LEFT JOIN table2
ON table1.column_name=table2.column_name;

SQL RIGHT JOIN 关键字

RIGHT JOIN 关键字从右表(table2)返回所有行,即使左表中没有匹配。如果左表中没有匹配,则结果为NULL。

SELECT column_name(s)
FROM table1
RIGHT JOIN table2
ON table1.column_name=table2.column_name;

SQL FULL OUTER JOIN关键字

FULL OUTER JOIN 关键字只要左表和右表其中一个表存在匹配,则返回行。

SELECT column_name(s)
FROM table1
FULL OUTER JOIN table2
ON table1.column_name=table2.column_name;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值