1. 取整函数: round
语法: round(double a) 返回值: BIGINT 说明: 返回double类型的整数值部分(遵循四舍五入) 举例: hive> select round(3.1415926) from lxw_dual; 3 hive> select round(3.5) from lxw_dual; 4 hive> create table lxw_dual as select round(9542.158) fromlxw_dual; hive> describe lxw_dual; _c0 bigint 2. 指定精度取整函数: round 语法: round(double a, int d) 返回值: DOUBLE 说明: 返回指定精度d的double类型 举例: hive> select round(3.1415926,4) from lxw_dual; 3.1416 3. 向下取整函数: floor 语法: floor(double a) 返回值: BIGINT 说明: 返回等于或者小于该double变量的最大的整数 举例: hive> select floor(3.1415926) from lxw_dual; 3 hive> select floor(25) from lxw_dual; 25 4. 向上取整函数: ceil 语法: ceil(double a) 返回值: BIGINT 说明: 返回等于或者大于该double变量的最小的整数 举例: hive> select ceil(3.1415926) from lxw_dual; 4 hive> select ceil(46) from lxw_dual; 46 5. 向上取整函数: ceiling 语法: ceiling(double a) 返回值: BIGINT 说明: 与ceil功能相同 举例: hive> select ceiling(3.1415926) from lxw_dual; 4 hive> select ceiling(46) from lxw_dual; 46 6. 取随机数函数: rand 语法: rand(),rand(int seed) 返回值: double 说明: 返回一个0到1范围内的随机数。如果指定种子seed,则会等到一个稳定的随机数序列 举例: hive> select rand() from lxw_dual; 0.5577432776034763 hive> select rand() from lxw_dual; 0.6638336467363424 hive> select rand(100) from lxw_dual; 0.7220096548596434 hive> select rand(100) from lxw_dual; 0.7220096548596434 7. 自然指数函数: exp 语法: exp(double a) 返回值: double 说明: 返回自然对数e的a次方 举例: hive> select exp(2) from lxw_dual; 7.38905609893065 自然对数函数: ln 语法: ln(double a) 返回值: double 说明: 返回a的自然对数 举例: hive> select ln(7.38905609893065) from lxw_dual; 2.0 8. 以10为底对数函数: log10 语法: log10(double a) 返回值: double 说明: 返回以10为底的a的对数 举例: hive> select log10(100) from lxw_dual; 2.0 9. 以2为底对数函数: log2 语法: log2(double a) 返回值: double 说明: 返回以2为底的a的对数 举例: hive> select log2(8) from lxw_dual; 3.0 10. 对数函数: log 语法: log(double base, double a) 返回值: double 说明: 返回以base为底的a的对数 举例: hive> select log(4,256) from lxw_dual; 4.0 11. 幂运算函数: pow 语法: pow(double a, double p) 返回值: double 说明: 返回a的p次幂 举例: hive> select pow(2,4) from lxw_dual; 16.0 12. 幂运算函数: power 语法: power(double a, double p) 返回值: double 说明: 返回a的p次幂,与pow功能相同 举例: hive> select power(2,4) from lxw_dual; 16.0 13. 开平方函数: sqrt 语法: sqrt(double a) 返回值: double 说明: 返回a的平方根 举例: hive> select sqrt(16) from lxw_dual; 4.0 14. 二进制函数: bin 语法: bin(BIGINT a) 返回值: string 说明: 返回a的二进制代码表示 举例: hive> select bin(7) from lxw_dual; 111 15. 十六进制函数: hex 语法: hex(BIGINT a) 返回值: string 说明: 如果变量是int类型,那么返回a的十六进制表示;如果变量是string类型,则返回该字符串的十六进制表示 举例: hive> select hex(17) from lxw_dual; 11 hive> select hex(‘abc’) from lxw_dual; 616263 16. 反转十六进制函数: unhex 语法: unhex(string a) 返回值: string 说明: 返回该十六进制字符串所代码的字符串 举例: hive> select unhex(‘616263’) from lxw_dual; abc hive> select unhex(‘11’) from lxw_dual; - hive> select unhex(616263) from lxw_dual; abc 17. 进制转换函数: conv 语法: conv(BIGINT num, int from_base, int to_base) 返回值: string 说明: 将数值num从from_base进制转化到to_base进制 举例: hive> select conv(17,10,16) from lxw_dual; 11 hive> select conv(17,10,2) from lxw_dual; 10001 18. 绝对值函数: abs 语法: abs(double a) abs(int a) 返回值: double int 说明: 返回数值a的绝对值 举例: hive> select abs(-3.9) from lxw_dual; 3.9 hive> select abs(10.9) from lxw_dual; 10.9 19. 正取余函数: pmod 语法: pmod(int a, int b),pmod(double a, double b) 返回值: int double 说明: 返回正的a除以b的余数 举例: hive> select pmod(9,4) from lxw_dual; 1 hive> select pmod(-9,4) from lxw_dual; 3 20. 正弦函数: sin 语法: sin(double a) 返回值: double 说明: 返回a的正弦值 举例: hive> select sin(0.8) from lxw_dual; 0.7173560908995228 21. 反正弦函数: asin 语法: asin(double a) 返回值: double 说明: 返回a的反正弦值 举例: hive> select asin(0.7173560908995228) from lxw_dual; 0.8 22. 余弦函数: cos 语法: cos(double a) 返回值: double 说明: 返回a的余弦值 举例: hive> select cos(0.9) from lxw_dual; 0.6216099682706644 23. 反余弦函数: acos 语法: acos(double a) 返回值: double 说明: 返回a的反余弦值 举例: hive> select acos(0.6216099682706644) from lxw_dual; 0.9 24. positive函数: positive 语法: positive(int a), positive(double a) 返回值: int double 说明: 返回a 举例: hive> select positive(-10) from lxw_dual; -10 hive> select positive(12) from lxw_dual; 12 25. negative函数: negative 语法: negative(int a), negative(double a) 返回值: int double 说明: 返回-a 举例: hive> select negative(-5) from lxw_dual; 5 hive> select negative(8) from lxw_dual; 更多精彩内容请关注:http://bbs.superwu.cn 关注超人学院微信二维码: |
hive---数值计算
时间: 2024-11-13 06:52:16
hive---数值计算的相关文章
hive支持sql大全
转自:http://www.aboutyun.com/thread-7316-1-1.html 一.关系运算:1. 等值比较: = 语法:A=B 操作类型:所有基本类型 描述: 如果表达式A与表达式B相等,则为TRUE:否则为FALSE 举例:hive>select 1 from lxw_dual where 1=1; 2. 不等值比较: <> 语法: A <> B 操作类型: 所有基本类型 描述: 如果表达式A为NULL,或者表达式B为NULL,返回NULL:如果表达式A与
Hive常见内置函数及其使用
函数分类 HIVE CLI命令 显示当前会话有多少函数可用 SHOW FUNCTIONS; 显示函数的描述信息 DESC FUNCTION concat; 显示函数的扩展描述信息 DESC FUNCTION EXTENDED concat; 简单函数 函数的计算粒度为单条记录. 关系运算 数学运算 逻辑运算 数值计算 类型转换 日期函数 条件函数 字符串函数 统计函数 聚合函数 函数处理的数据粒度为多条记录. sum()-求和 count()-求数据量 avg()-求平均直 distinct-求
hive内置函数大全
====================================== 一.关系函数 1.等值比较:= 语法:A=B 操作类型:所有基本类型 2.不等值比较:<> 语法:A<>B 操作类型:所有基本类型 3.小于比较:< 语法:A<B 操作类型:所有基本类型 4.空值判断:IS NULL 语法:a is null 操作类型:所有类型 5.非空判断:IS NOT NULL 语法:a is not null 操作类型:所有基本类型 6.LIKE比较:LIKE 语法:A
Hive函数大全
一.关系运算: 1. 等值比较: = 语法:A=B 操作类型:所有基本类型 描述: 如果表达式A与表达式B相等,则为TRUE:否则为FALSE 举例: hive> select 1 from lxw_dual where 1=1; 1 2. 不等值比较: <> 语法: A <> B 操作类型: 所有基本类型 描述: 如果表达式A为NULL,或者表达式B为NULL,返回NULL:如果表达式A与表达式B不相等,则为TRUE:否则为FALSE 举例: hive> select
hive的UDF 函数(User-Defined-Function)
UDF函数可以直接应用于select语句,对查询结构做格式化处理后,再输出内容. 关系运算 等值比较: = 语法: A = B 操作类型: 所有基本类型 描述: 如果表达式A与表达式B相等,则为TRUE:否则为FALSE 举例: hive> select 1 from dual where 1=1; 1 不等值比较: <> 语法: A <> B 操作类型: 所有基本类型 描述: 如果表达式A为NULL,或者表达式B为NULL,返回NULL:如果表达式A与表达式B不相等,则为T
hive 函数大全
一.关系运算: 1. 等值比较: = 语法:A=B 操作类型:所有基本类型 描述:如果表达式A与表达式B相等,则为TRUE:否则为FALSE 举例: hive>select 1 from lxw_dual where 1=1; 1 2. 不等值比较: <> 语法: A <> B 操作类型:所有基本类型 描述:如果表达式A为NULL,或者表达式B为NULL,返回NULL:如果表达式A与表达式B不相等,则为TRUE:否则为FALSE 举例: hive> select1 fr
Hive函数详解与案列实战
1.Hive系统内置函数 1.1.数值计算函数 1.取整函数: round 语法: round(double a)返回值: BIGINT说明: 返回double类型的整数值部分 (遵循四舍五入) hive> select round(3.1415926) from tableName; 3 hive> select round(3.5) from tableName; 4 hive> create table tableName as select round(9542.158) fro
学习Hive和Impala必看经典解析
Hive和Impala作为数据查询工具,它们是怎样来查询数据的呢?与Impala和Hive进行交互,我们有哪些工具可以使用呢? 我们首先明确Hive和Impala分别提供了对应查询的接口: (1)命令行shell: 1. Impala:impala shell 2. Hive:beeline(早期hive的命令行版本是hive shell,现在基本不使用) (2)Hue Web UI: 1.Hue里面提供了 Hive查询编辑器 2.Hue里面提供了Impala查询编辑器 3.Hue里面提供了元数
Hive报错 Failed with exception java.io.IOException:java.lang.IllegalArgumentException: java.net.URISyntaxException: Relative path in absolute URI: ${system:user.name%7D
报错信息如下 Failed with exception java.io.IOException:java.lang.IllegalArgumentException: java.net.URISyntaxException: Relative path in absolute URI: ${system:user.name%7D 解决方法: 编辑 hive-site.xml 文件,添加下边的属性 <property> <name>system:java.io.tmpdir<
Spark 整合hive 实现数据的读取输出
实验环境: linux centOS 6.7 vmware虚拟机 spark-1.5.1-bin-hadoop-2.1.0 apache-hive-1.2.1 eclipse 或IntelJIDea 本次使用eclipse. 代码: import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaSparkContext; import org.apache.spark.sql.DataFrame; import o