一、内置函数

  1.一般常用函数  

1.取整函数
round() 当传入第二个参数则为精度
bround() 银行家舍入法:为5时,前一位为偶则舍,奇则进。
2.向下取整
floor()
3.向上取整
ceil/ceiling()
4.生成随机数
rand () 范围[0,1),传入种子时生成稳定随机数
5.自然指数函数
exp () e的n次方
log10 () 10为底的对数函数
ln() e为底的对数函数
log(base,v)base为底的函数
6.幂函数
pow/power (base,exponent)
7.根函数
aqrt() 开平发
cbrt() 开立方
8.绝对值函数
abs()
9.进制转换
bin() 转二进制
hex() 转十六进制
unhex() 反转十六进制
conv(v,from,to) 进制转换函数
10时间函数
unix_timestamp() 获取时间
from_unixtime(ut,formats) ut转为日期字符串
unix_timestamp(timestr,fs) 日期转化ut
to_data(timestr) 返回日期部分
year(timestr) 返回指定部分,其他类似
datediff(endDate,startD) 日期比较函数(返回日期之间的天数)
date_add(startDate,days) 日期增加,返回当前日期计算后的日期字符串
date_sub(startDate,days) 日期减少

  2.字符串常用函数

1.取长度
length()
2.反转
reverse()
3.字符串连接函数
concat(strS) 无分隔符连接
concat_ws(separator,strS) 分隔符连接
4.字符串截取
substr/substring(str,index) 为正截取至此,为负截取后index个
~~~~(str,index,length) 从index截取length个字符,正左负右
5.大小写转换
upper/ucase ()
lower/lcase ()
6.去空格函数
trim() 两边去空格
ltrim() 左边去空格
rtrim() 右边去空格
7.正则表达式
regexp_replace(str,rge,replace) 替换字符串
regexp_extract(str,reg,index) 查找匹配字符,0返回全部,1返回第一个括号里的
8.URL解析函数
parse_url (str,’{extractPart}’[,’{extractKey}’])
选项有:[HOST,PATH,QUERY,REF,PROTOCOL,FILE,AUTHORITY,USERINFO]
select parse_url('http://facebook.com/path/p1.php?query=1', 'HOST') from dual;---facebook.com​
9.json函数
get_json_object(jsonstr,'$.name')
10.字符串生成和补足函数
space(n) 空字符串
repeat(str,n) 重复字符串
lpad(str,legth,addstr) 左补足
split(str,splitstr) 字符串分割

二、自定义函数

自定义函数加载步骤 -> 只对当前会话有效
(1)新建项目 - JavaProject
(2)将hive-exec-1.2.2.jar添加至构建路径中
(3)新建包 -> 新建类(继承UDF)
(4)新建方法evaluate -> 指定返回值类型和参数列表
(5)导出项目 -> jar包(只需要包含src下的内容)
(6)上传jar包至Linux系统
(7)打开Hive会话
(8)加载jar包:add jar /home/bigdata/udf.jar; -> 将jar包添加至构建路径(类的搜索加载路径)
(9)将jar包中的类进行函数的命名
create temporary function sub as 'com.sand.udf.SubString';
(10)show functions; -> 验证是否添加成功

三、创建虚表

为了方便测试,可仿照oracle创建dual表
1.新建一个dual表
create table dual(dummy string);
2.创建仅包含X的文件
echo X >/home/hadoop/dual.txt
3.上传数据
load data local inpath '/home/hadoop/dual.txt' overwrite into table dual;
4.测试
select 1+1 from dual ; 返回2则成功

hive的内置函数和自定义函数的更多相关文章

  1. Hive学内置条件和字符串函数

    https://blog.csdn.net/skywalker_only/article/details/38752003 条件函数 下表为Hive支持的一些条件函数. 返回类型 函数名 描述 T i ...

  2. Hive内置函数和自定义函数的使用

    一.内置函数的使用 查看当前hive版本支持的所有内置函数 show function; 查看某个函数的使用方法及作用,比如查看upper函数 desc function upper; 查看upper ...

  3. [Hive_6] Hive 的内置函数应用

    0. 说明 Hive 的内置函数的基本操作 | 时间函数 | String 函数 | 条件语句 | explode | split | substring 1. 基本操作 查看函数 show func ...

  4. Python之函数(自定义函数,内置函数,装饰器,迭代器,生成器)

    Python之函数(自定义函数,内置函数,装饰器,迭代器,生成器) 1.初始函数 2.函数嵌套及作用域 3.装饰器 4.迭代器和生成器 6.内置函数 7.递归函数 8.匿名函数

  5. Python内置的字符串处理函数整理

    Python内置的字符串处理函数整理 作者: 字体:[增加 减小] 类型:转载 时间:2013-01-29我要评论 Python内置的字符串处理函数整理,收集常用的Python 内置的各种字符串处理 ...

  6. PHP内置的字符串处理函数

    字符串的特点    1.其他类型的数据用在字符串类型处理函数中,会自动将其转化成字符串后,在处理 <?php echo substr("abcdefghijklmn",2,4 ...

  7. thinkPHP内置字符串截取msubstr函数用法详解

    作者:陈达辉 字体:[增加 减小] 类型:转载 时间:2016-11-15 我要评论 这篇文章主要介绍了thinkPHP内置字符串截取函数用法,结合实例形式分析了thinkPHP内置的字符串截取函数功 ...

  8. python内置常用高阶函数(列出了5个常用的)

    原文使用的是python2,现修改为python3,全部都实际输出过,可以运行. 引用自:http://www.cnblogs.com/duyaya/p/8562898.html https://bl ...

  9. jquery (内置遍历数组的函数,事件)

    内置遍历数组的函数: 1. $.map(array, function() { }); 取到数组或者对象array中每一项进行遍历  然后在function中处理: var attr = [1,2,3 ...

  10. MySQL之运算符与函数、自定义函数

    一自定义函数简介 (1)自定义函数定义 用户自定义函数(user-defined function,UDF)是一种对MySQL数据库扩展的途径,其用法与内置函数相同. (2)自定义函数的两个必要条件 ...

随机推荐

  1. poj 2253 Frogger 最小瓶颈路(变形的最小生成树 prim算法解决(需要很好的理解prim))

    传送门: http://poj.org/problem?id=2253 Frogger Time Limit: 1000MS   Memory Limit: 65536K Total Submissi ...

  2. UVA - 1197 (简单并查集计数)

    Severe acute respiratory syndrome (SARS), an atypical pneumonia of unknown aetiology, was recognized ...

  3. 网络测量中基于Sketch方法的调查

    目录 LD Sketch SeqHash What's New reversible sketch Count-Sketch和Count-min sketch Diamond Sketch: Accu ...

  4. 多线程系列 - 基础篇01 - 线程基本概念 & 线程优先级 & 守护线程 60%

    1.什么是线程 将线程理解为轻量级进程,它与进程的最大的区别是: 多个线程共享一个进程资源: 对于OS的许多资源的分配和管理(如内存)通常都是进程级别的,线程只是os调度的最小单位: 相对于进程来说更 ...

  5. Java实现目的选层电梯的调度

    一.前言 本次博客我将简单介绍一下前两次的电梯作业,并简单解析一下我的程序结构,进一步对我的第二次作业的算法核心和一些想法做一些分享,我的电梯设计算法并不是由调度器来决定电梯的捎带与否,而是由电梯自主 ...

  6. 一个百度MAP导航的基础封装

    项目中需要根据点击时候点击的内容,输入百度地图查找并展示规划等相关功能 于是封装了一个单独的百度map的html页面以供调用 功能包括了 ①展示底图 ②切换卫星图,切换卫星路线图,切换普通地图 ③通过 ...

  7. 解决mysql远程登录

    MySQL不允许远程登录,所以远程登录失败了,解决方法如下: 在装有MySQL的机器上登录MySQL mysql -u root -p密码 执行use mysql; 执行update user set ...

  8. 怎样在Win7系统中搭建Web服务器

    一.搭建web服务 1.打开控制面板,选择并进入“程序”,双击“打开或关闭Windows服务”,在弹出的窗口中选择“Internet信息服务”下面所有的选项,点击确定后,开始更新服务. 2.更新完成后 ...

  9. Delphi 调试连接 任意Android手机/平板/盒子

    Delphi有时候无法连接调试一些手机,解决方案: 1.安装Google USB Driver 2.通过设备管理器查看手机或平板USB的VID,PID 3.修改你的电脑上的android_winusb ...

  10. 使用jdk生成自签发证书(过程总结)

    前言: 最近在做华为NB-IoT接口开发,需要用到双向认证,就去学了一下. 然后我将过程总结了一下. 相关华为论坛链接:http://developer.huawei.com/ict/forum/th ...