1.COALESCE( value1,value2,... )
  
  The COALESCE function returns the fist not NULL value from the list of values. If all the values in the list are NULL, then it returns NULL.
  
  Example: COALESCE(NULL,NULL,5,NULL,4) returns 5;
  
  coalesce()函数,在处理空值时,'' 和NULL是不一样的,函数认为NULL是空值,但'' 不是空值,
  
  故coalesce('','test')会返回'',而不是test;而coalesce(NULL,'test')回返回test;
  
  2.NTILE,ROW_NUMBER,RANK,DENSE_RANK;
  
  ①NTILE:用户将分组数据按照顺序切分成N片,返回当前切片值。
  
  NTILE(n),用于将分组数据按照顺序切分成n片,返回当前切片值
  
  NTILE不支持ROWS BETWEEN,比如 NTILE(2) OVER(PARTITION BY cookieid ORDER BY createtime ROWS BETWEEN 3 PRECEDING AND CURRENT ROW)
  
  如果切片不均匀,默认增加第一个切片的分布
  
  SELECT
  
  cookieid,
  
  createtime,
  
  pv,
  
  NTILE(2) OVER(PARTITION BY cookieid ORDER BY createtime) AS rn1, --分组内将数据分成2片
  
  NTILE(3) OVER(PARTITION BY cookieid ORDER BY createtime) AS rn2, --分组内将数据分成3片
  
  NTILE(4) OVER(ORDER BY createtime) AS rn3 --将所有数据分成4片
  
  FROM lxw1234
  
  ORDER BY cookieid,createtime;
  
  cookieid day pv rn1 rn2 rn3
  
  -------------------------------------------------
  
  cookie1 2015-04-10 1 1 1 1
  
  cookie1 2015-04-11 5 1 1 1
  
  cookie1 2015-04-12 7 1 1 2
  
  cookie1 2015-04-13 3 1 2 2
  
  cookie1 2015-04-14 2 2 2 3
  
  cookie1 2015-04-15 4 2 3 3
  
  cookie1 2015-04-16 4 2 3 4
  
  cookie2 2015-04-10 2 1 1 1
  
  cookie2 2015-04-11 3 1 1 1
  
  cookie2 2015-04-12 5 1 1 2
  
  cookie2 2015-04-13 6 1 2 2
  
  cookie2 2015-04-14 3 2 2 3
  
  cookie2 2015-04-15 9 2 3 4
  
  cookie2 2015-04-16 7 2 3 4
  
  比如,统计一个cookie,pv数最多的前1/3的天
  
  SELECT
  
  cookieid,
  
  createtime,
  
  pv,
  
  NTILE(3) OVER(PARTITION BY cookieid ORDER BY pv DESC) AS rn
  
  FROM lxw1234;
  
  --rn = 1 的记录,就是我们想要的结果
  
  cookieid day pv rn
  
  ----------------------------------
  
  cookie1 2015-04-12 7 1
  
  cookie1 2015-04-11 5 1
  
  cookie1 2015-04-15 4 1
  
  cookie1 2015-04-16 4 2
  
  cookie1 2015-04-13 3 2
  
  cookie1 2015-04-14 2 3
  
  cookie1 2015-04-10 1 3
  
  cookie2 2015-04-15 9 1
  
  cookie2 2015-04-16 7 1
  
  cookie2 2015-04-13 6 1
  
  cookie2 2015-04-12 5 2
  
  cookie2 2015-04-14 3 2
  
  cookie2 2015-04-11 3 3
  
  cookie2 2015-04-10 2 3
  
  ②ROW_NUMBER:Row_number函数返回一个唯一的值,当碰到相同数据时,排名按照记录集中记录的顺序依次递增。
  
  ROW_NUMBER() –从1开始,按照顺序,生成分组内记录的序列
  
  –比如,按照pv降序排列,生成分组内每天的pv名次
  
  ROW_NUMBER() 的应用场景非常多,再比如,获取分组内排序第一的记录;获取一个session中的第一条refer等。
  
  SELECT
  
  cookieid,
  
  createtime,
  
  pv,
  
  ROW_NUMBER() OVER(PARTITION BY cookieid ORDER BY pv desc) AS rn
  
  FROM lxw1234;
  
  cookieid day pv rn
  
  -------------------------------------------
  
  cookie1 2015-04-12 7 1
  
  cookie1 2015-04-11 5 2
  
  cookie1 2015-04-15 4 3
  
  cookie1 2015-04-16 4 4
  
  cookie1 2015-04-13 3 5
  
  cookie1 2015-04-14 2 6
  
  cookie1 2015-04-10 1 7
  
  cookie2 2015-04-15 9 1
  
  cookie2 2015-04-16 7 2
  
  cookie2 2015-04-13 6 3
  
  cookie2 2015-04-12 5 4
  
  cookie2 2015-04-14 3 5
  
  cookie2 2015-04-11 3 6
  
  cookie2 2015-04-10 2 7
  
  ③RANK 和 DENSE_RANK:
  
  RANK:Rank函数返回一个唯一的值,除非遇到相同的数据时,此时所有相同数据的排名是一样的,同时会在最后一条相同记录和下一条不同记录的排名之间空出排名。
  
  DENSE_RANK:Dense_rank函数返回一个唯一的值,除非当碰到相同数据时,此时所有相同数据的排名都是一样的。
  
  —RANK() 生成数据项在分组中的排名,排名相等会在名次中留下空位
  
  —DENSE_RANK() 生成数据项在分组中的排名,排名相等会在名次中不会留下空位
  
  SELECT
  
  cookieid,
  
  createtime,
  
  pv,
  
  RANK() OVER(PARTITION BY cookieid ORDER BY pv desc) AS rn1,
  
  DENSE_RANK() OVER(PARTITION BY cookieid ORDER BY pv desc) AS rn2,
  
  ROW_NUMBER() OVER(PARTITION BY cookieid ORDER BY pv DESC) AS rn3
  
  FROM lxw1234
  
  WHERE cookieid = 'cookie1';
  
  cookieid day pv rn1 rn2 rn3

Slf4j public class TestThreadlocal {
private static ThreadLocal<String> local = ThreadLocal.withInitial(() -> "init");

public static void main(String[] args) throws InterruptedException {
Runnable r = new TT();
new Thread(r, "thread1").start();
Thread.sleep(2000);
new Thread(r, www.michenggw.com"thread2"www.baishenyvip.com).start();
log.info("exit"www.bsylept.com);
private static class TT implements Runnable {
@Override
public void run(www.jiahuayulpt.com ) {
log.info(local.get(www.yongshi123.cn));
local.set(Thread.currentThread().getName(www.dfgjpt.com));
log.info("set local name and get: {}", local.get());
  
  --------------------------------------------------
  
  cookie1 2015-04-12 7 1 1 1
  
  cookie1 2015-04-11 5 2 2 2
  
  cookie1 2015-04-15 4 3 3 3
  
  cookie1 2015-04-16 4 3 3 4
  
  cookie1 2015-04-13 3 5 4 5
  
  cookie1 2015-04-14 2 6 5 6
  
  cookie1 2015-04-10 1 7 6 7
  
  rn1: 15号和16号并列第3, 13号排第5
  
  rn2: 15号和16号并列第3, 13号排第4
  
  rn3: 如果相等,则按记录值排序,生成唯一的次序,如果所有记录值都相等,或许会随机排吧。

关于Hive中常用函数需要注意的点小合集的更多相关文章

  1. LoadRunner中常用函数参考手册

    基础篇1:LoadRunner中常用函数参考手册 常用函数列表 web_url web_submmit_form VS web_submmit_data VS web_custom_request w ...

  2. Hive中日期函数总结

    --Hive中日期函数总结: --1.时间戳函数 --日期转时间戳:从1970-01-01 00:00:00 UTC到指定时间的秒数 select unix_timestamp(); --获得当前时区 ...

  3. hive中标准偏差函数stddev()详细讲解

    1.标准偏差概念 标准偏差(Std Dev,Standard Deviation) -统计学名词.一种度量数据分布的分散程度之标准,用以衡量数据值偏离算术平均值的程度.标准偏差越小,这些值偏离平均值就 ...

  4. PHP 常用函数库和一些实用小技巧

    PHP 常用函数库和一些实用小技巧 作者: 字体:[增加 减小] 类型:转载   包括文件读取函式,文件写入函式,静态页面生成函式,目录删除函式等   文件读取函式 //文件读取函式 function ...

  5. OpenCV图像处理中常用函数汇总(1)

    //俗话说:好记性不如烂笔头 //用到opencv 中的函数时往往会一时记不起这个函数的具体参数怎么设置,故在此将常用函数做一汇总: Mat srcImage = imread("C:/Us ...

  6. JavaScript中常用函数(入门级)(持续更新)

    本文中枫竹梦介绍一些JavaScript中入门级的常用函数,对于已经过了入门的童鞋可选择略过,都是一些非常实用的函数.如果发现什么问题,欢迎讨论. 问题列表 Q1: 设计一个函数repeatIt(st ...

  7. Hive中自定义函数

    Hive的自定义的函数的步骤: 1°.自定义UDF extends org.apache.hadoop.hive.ql.exec.UDF 2°.需要实现evaluate函数,evaluate函数支持重 ...

  8. 5. openCV中常用函数学习

    一.前言 经过两个星期的努力,一边学习,一边写代码,初步完成了毕业论文系统的界面和一些基本功能,主要包括:1 数据的读写和显示,及相关的基本操作(放大.缩小和移动):2 样本数据的选择:3 数据归一化 ...

  9. javascript中常用函数汇总

    js中函数很多,在实际项目开发中,函数的应用可以很大程度上简化我们的代码,所以在此记下开发中js中常用的函数,增强记忆. 1.isNaN(X):函数用于检查其参数是否是非数字值. 如果 x 是特殊的非 ...

随机推荐

  1. JAVA实现用户的权限管理

    一:写在前面 前两天有个同学问我,那个系统不同的用户登陆不同的页面不同,要写很多个页面啊!而每个用户的在系统中拥有不同的权限,可以访问不同的页面是怎么实现的??那低权限的在浏览器输入高权限的人的url ...

  2. Codechef TAPAIR Counting the important pairs 随机化、树上差分

    传送门 题意:给出一个$N$个点.$M$条边的无向连通图,求有多少组无序数对$(i,j)$满足:割掉第$i$条边与第$j$条边之后,图变为不连通.$N \leq 10^5 , M \leq 3 \ti ...

  3. nginx 安装问题

    yum -y install  xxx pcre-devel  openssl-devel   zlib-devel  这个三个包需要 有时候,我们需要单独安装nginx,来处理大量的下载请求.单独在 ...

  4. CYJian的水题大赛

    实在没忍住就去打比赛了然后一耗就是一天 最后Rank19还是挺好的(要不是乐多赛不然炸飞),这是唯一一套在Luogu上号称水题大赛的而实际上真的是水题大赛的比赛 好了我们开始看题 T1 八百标兵奔北坡 ...

  5. 一台服务器多实例mysql做主从复制

    在一台服务器上开两个端口的mysql(3306.3307),做成主从复制环境 1)安装mysql(安装过程这里就不做过多介绍) 参考:http://www.cnblogs.com/kevingrace ...

  6. javaScript常用API合集

    节点 1.1 节点属性 Node.nodeName   //返回节点名称,只读 Node.nodeType   //返回节点类型的常数值,只读 Node.nodeValue  //返回Text或Com ...

  7. 研究C语言的新型编译环境TCC

    C语言综合研究1 搭建一个tcc环境 研究过程: 问题引出:为什么要使用tcc环境,甚至连图形界面都没有,为什么要使用这样的化境? 按照我们学习的本质来讲,可能是为了体验C语言底层的相关特性,但是在研 ...

  8. answer my questions from the book<构建之法>.

    1)何为文档:文档时在一个项目进行的一生中所有记忆的集合.有需求分析.功能设计.在实现功能过程中也可以有一系列文档记录.测试文档等等. 2)结对工作等找队友会花费大量时间致耽误项目否:正如老师所讲,从 ...

  9. (Alpha)Let's-版本发布说明

    我们的Let’s APP发布了! (下载地址在“下载与安装”部分) Alpha版本功能 Alpha版本是我们发布的第一个版本,所以仅实现了活动实体和用户实体之间的基础联系功能. 基本功能 登录和注册 ...

  10. Ajax的使用~~~整理

    之前对于ajax没有详细的学习,只是碰到的时候,就记一点,不是很有条理.虽然常用的都会用,但真经不起询问,知其然而不知其所以然,所以专门看了一下<JavaScript高级程序设计>中对aj ...