case 表达式:简单case表达式,搜索case表达式
简单case表达式:
case后为条件(可以是列名)
若等于when后面的值,则执行then
都不满足,执行else结果
搜索case表达式(推荐使用)
多表联结实现:
窗口函数(OLAP: online analytical processing):可以做一些排序排名,聚合函数一般无法做到
语法:(partition by可以省略)
RANK
DENSE_RANK
ROW_NUMBER
需求:对bedroom是分组,并对相同数量的bedrooms的price进行排列
省略partition by(相当于少了分组条件):按照price升序排列,类似于一个单独的orderby,只不过多了一个ranking
RANK:并列,不连续
DENSE_RANK:并列连续
ROW_NUMBER:无并列,顺序排列
常用的聚合函数也可作为窗口函数来使用
累加:
累加之后再求平均:空值不参与做平均
需求:做三天的移动平均:ABC,BCD……
row 2 preceding:除本身外可以向前看两行
除本身外,前看一天,后看一天:rows between 1 preceding and 1 following
只有following……