1 前言
SQL进阶次要介绍谓词、CASE表达式、嵌套子查问、连贯(以列为单位对表进行连贯)和UNION运算(表为单位)。
2 SQL进阶
2.1 谓词
- LIKE
介绍LIKE之前,先介绍通配符,MySQL只反对百分号(%)和下划线(_),百分号代替0个或多个字符,下划线替换一个字符。通配符和正则表达式不是一回事,有趣味的能够去搜一下正则表达式。LIKE操作符能够了解等于(=)。
SELECT website ,city FROM web_city WHERE website like '%o%' and city like '_谷'
- BETWEEN
BETWEEN操作符取某个字段在某个范畴之间,能够数值、文本和日期。常跟AND搭配,BETWEEN....AND....。
SELECT website FROM web_city WHERE website BETWEEN 'A' AND 'H'
- IS NULL
SQL中NULL值的判断,不能用等于号(=)或者LIKE,用IS NULL。NULL值就是空值,啥也没有,web_city中为了显示,写了NULL,其实这个NULL是字符,不是空值哈,请留神。写空值间接'',就能够了。引号内啥也没有。
SELECT website,city FROM web_city WHERE website is NULL
- IN
IN操作符也是取某个字段在范畴之内,绝对BETWEEN AND,IN的范畴更加的明确。
SELECT website,city FROM web_city WHERE website in ('Google','淘宝','深圳')
- EXIST
EXIST多用于多表查问中,因为独自判断某条记录是否存在,没啥意思。举个例子。
SELECT * FROM web_city WHERE EXISTS (SELECT * from city_nation WHERE city ='硅谷') (1)SELECT * FROM web_city WHERE true (2)
第一条语句相当于第二条语句的意思,返回全副全副记录。
SELECT * FROM web_city WHERE EXISTS (SELECT * from city_nation WHERE web_city.city = city_nation.city)
2.2 CASE 表达式
CASE <单值表达式> WHEN <表达式值> THEN <SQL语句或返回值> WHEN <表达式值> THEN <SQL语句或返回值> ... WHEN <表达式值> THEN <SQL语句或返回值> ELSE <SQL语句或返回值>END
CASE表达式的语法如上,语法还是太形象,总结了CASE表达式的三种用法。
- 等值转换
SELECT *,(case when website ='Google' then '1' else '0' end ) as '等值转换' from web_city
case 表达式中,能够这样了解,case(假如)when(等于)就(then)其余(else)完结(end),最好用括号把整体括起来,看集体写法。
- 范畴转换
SELECT *,(case when website > 'A' then '1' else '0' end ) as '等值转换' from web_city
范畴转换就是就是把范畴内的值,转换为确定的值,比如说问题等级,当分数低于60,不及格,60~80,良好,80以上,优良。
- 列转行
SELECT max(case when website = 'Google' then city else '0' end ) as '列转行1',max(case when website = '淘宝' then city else '0' end ) as '列转行2' from web_city
通过以上语句,能够把city一列,转换为一行,我只转了前两个,后边相似。
2.3 嵌套子查问
嵌套子查问就是在select-from-where表达式中嵌套select-from-where表达式,select-from-where表达式能够放在where子句中和from子句中。当然还有with子句,有趣味的能够去百度理解一下。
- where 子句中的子查问
SELECT * FROM web_city where website in (SELECT website FROM web_city where website ='Google')
- from 子句中的子查问
SELECT S.* FROM (SELECT * FROM web_city where website ='Google') as S
2.4 连贯(join)
连贯(join)就是基于公共字段,进行表和表之间的联合。次要介绍内连贯,左连贯,右连贯和全连贯。内连贯就是把公共行取出来。左连贯以右边为主,右边的全取,左边有的取,没有的空。右连贯以左边为主。全连贯就是全取,mysql中不反对,能够在SQL Server上测试。
- 内连贯(INNER JOIN)
SELECT a.*,b.* from web_city a INNER JOIN city_nation b on a.city=b.city
- 左连贯(LEFT JOIN)
SELECT a.*,b.* from web_city a left JOIN city_nation b on a.city=b.city
- 右连贯(RIGHT JOIN)
SELECT a.*,b.* from web_city a RIGHT JOIN city_nation b on a.city=b.city
- 全连贯
SELECT a.*,b.* from web_city a FULL JOIN city_nation b on a.city=b.city
2.5 UNION 运算
UNION操作,去掉反复项。UNION ALL操作,不去掉反复项
- UNION
SELECT a.*,b.* from web_city a INNER JOIN city_nation b on a.city=b.cityUNION SELECT a.*,b.* from web_city a left JOIN city_nation b on a.city=b.city
- UNION ALL
SELECT a.*,b.* from web_city a INNER JOIN city_nation b on a.city=b.cityUNION ALLSELECT a.*,b.* from web_city a left JOIN city_nation b on a.city=b.city
3 总结
语法只是语法,还是要有思维在里边,我要用它干嘛,心愿大家多思考。
不求点赞,只求有用