关于sql:数据分析SQL进阶

44次阅读

共计 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 总结

语法只是语法,还是要有思维在里边,我要用它干嘛,心愿大家多思考。

不求点赞,只求有用

正文完
 0