共计 2581 个字符,预计需要花费 7 分钟才能阅读完成。
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.city
UNION
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.city
UNION ALL
SELECT a.*,b.* from web_city a left JOIN city_nation b on a.city=b.city
3 总结
语法只是语法,还是要有思维在里边,我要用它干嘛,心愿大家多思考。
不求点赞,只求有用