row_number:正常排序【1,2,3,4】 --必须有order by

rank:跳跃排序【1,2,2,4】 --必须有order by

dense rank :密集排序【1,2,2,3】-- 必须有order by

first :从desnse rank返回的集合中取出排在最前面的一个值的行。

last:从desnse rank返回集合中取出排在最后面的一个值的行。

first_value:返回组中数据窗口第一个值

last_value:返回组中数据窗口最后一个值。

三、数据分析函数

stddev:计算当前关于组的标准偏离

stddev_pop:该函数计算总体标准偏差,并返回总体变量的平方根。

STDDEV_SAMP:该函数计算累积样本标准偏离,并返回总体变量的平方根

VAR_POP       :该函数返回非空集合的总体变量(忽略null)

VAR_SAMP    :该函数返回非空集合的样本变量(忽略null)

VARIANCE     :如果表达式中行数为1,则返回0,如果表达式中行数大于1,则返回VAR_SAMP

COVAR_POP   :返回一对表达式的总体协方差

COVAR_SAMP :返回一对表达式的样本协方差

CORR        :返回一对表达式的相关系数

CUME_DIST   :计算一行在组中的相对位置

NTILE        : 将一个组分为"表达式"的散列表示(类于Hive的分桶原理)

PERCENT_RANK :和CUME_DIST(累积分配)函数类似

PERCENTILE_DISC :返回一个与输入的分布百分比值相对应的数据值

PERCENTILE_CONT :返回一个与输入的分布百分比值相对应的数据值

RATIO_TO_REPORT :该函数计算expression/(sum(expression))的值,它给出相对于总数的百分比

REGR_ (Linear Regression) Functions :这些线性回归函数适合最小二乘法回归线,有9个不同的回归函数可使用

四.行比较分析函数

LAG         :可以访问结果集中的其它行而不用进行自连接      -- 落后 -- lag(xx,1,0)

LEAD      :LEAD与LAG相反,LEAD3可以访问组中当前行之后的行    -- 领先 -- lead(xx,1,0)

连续3天登录用户

user_id 时间

解决问题-分析

可以通过对user_id分组排序后(rn),用登录日期减去序号rn.如果连续的话,则得到这个日期flag_dt会相同。

select user_id,count(1) cnt
select user_id,login_date,row_number() over (partition by user_id order by login date ) as 
from tmp.tmp_last_3_day 
group by user_id,date_sub(login_date,t.rn)
having count(1) >3;
java 生成区间内随机小数 java生成指定区间的随机数

java生成随机数经常用到,有时候我们还需要指定某个区间,比如随机生成一个在0-100这个范围内的整数,怎么写代码呢? package app; import java.util.Random; public class Test { public static void main(String[] args) throws Exception{ Random rando

docker tcp6改为tcp docker tcp连接数

由于使用DOCKER的时候,ESTABLISHED连接不会出现在netstat中:在运行中的docker容器中列出打开的套接字的方法方法:1. 查找docker的进程号 :docker inspect -f '``.`State`.`Pid`' <containerid> $ docker inspect -f '``.`State`.`Pid`' 49b98b2fbad2 18402.

java文本域怎么获取自己发出的内容 java获取文本框内容

输入流输出流实现文本读取在窗体中通过按钮控制,读取文档中的文本,在窗体中显示。import java.awt.FileDialog; import java.awt.FlowLayout; import java.awt.TextArea; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; impor