hive中的函数

COALESCE 函数 - PL/HQL 参考

COALESCE 函数返回第一个非 NULL 表达式。

语法

sql 复制代码
COALESCE(expr1, expr2 [, expr3, ...]); 

参数

参数 类型
exprN 任意 变量或表达式

注意事项

  • 当找到第一个非 NULL 表达式时,不会再评估后续表达式。
  • COALESCE 和 NVL 函数是同义词。

返回值

  • 第一个非 NULL 表达式
  • 如果所有表达式都评估为 NULL,则返回 NULL

返回类型

第一个非 NULL 表达式的数据类型。

示例

sql 复制代码
COALESCE(NULL, 1, 2, 3); 

结果:1

兼容性

支持的数据库系统包括 Oracle、IBM DB2、Teradata、Microsoft SQL Server、PostgreSQL、MySQL 和 Netezza。

版本

PL/HQL 0.03

NVL 函数 - PL/HQL 参考

NVL 函数返回第一个非 NULL 表达式。

语法

sql 复制代码
NVL(expr1, expr2 [, expr3, ...]); 

参数

参数 类型
exprN 任意 变量或表达式

注意事项

  • 当找到第一个非 NULL 表达式时,不会再评估后续表达式。
  • NVL 和 COALESCE 函数是同义词。

返回值

  • 第一个非 NULL 表达式
  • 如果所有表达式都评估为 NULL,则返回 NULL

返回类型

第一个非 NULL 表达式的数据类型。

示例

sql 复制代码
NVL(NULL, 1); 

结果:1

兼容性

支持的数据库系统包括 Oracle、IBM DB2 和 Netezza。

版本

PL/HQL 0.01

CAST 函数 - PL/HQL 参考

CAST 函数将一个表达式转换为指定的数据类型。

语法

sql 复制代码
CAST(expression AS datatype[(length)]); 

注意事项

  • 如果对 CAST 作为 CHAR 或 VARCHAR 函数指定了长度,结果字符串将被截断为该长度。

示例 1

将表达式转换为指定长度的字符串:

sql 复制代码
CAST('Abc' AS CHAR(1)); 
--
A

示例 2

截断时间戳字符串:

sql 复制代码
CAST(TIMESTAMP '2015-03-12 10:58:34.111' AS CHAR(10));
--
2015-03-12

兼容性

支持的数据库系统包括 Oracle、Microsoft SQL Server、IBM DB2、Teradata、PostgreSQL、MySQL 和 Netezza。

版本

PL/HQL 0.03

CHAR 函数 - PL/HQL 参考

CHAR 函数将一个数字转换为字符串。

语法

sql 复制代码
CHAR(num_expression); 

返回类型

STRING

示例 1

将数字转换为字符串:

sql 复制代码
CHAR(1000); 
--
1000

兼容性

支持的数据库系统包括 IBM DB2。

版本

PL/HQL 0.03

CONCAT 函数 - PL/HQL 参考

CONCAT 函数用于连接两个或多个字符串。

语法

sql 复制代码
CONCAT(expr, expr2 [, expr3, ...]); 

注意事项

  • 如果一个表达式的值为 NULL,则将其视为空字符串。
  • 仅当所有表达式的值均为 NULL 时,CONCAT 函数返回 NULL。

返回类型

STRING

示例

sql 复制代码
CONCAT('a', 'b', NULL, 'c'); 

结果:abc

兼容性

支持的数据库系统包括 Oracle、IBM DB2、Teradata、Microsoft SQL Server、PostgreSQL、MySQL 和 Netezza。

版本

PL/HQL 0.3.1

字符串拼接操作符 ||

您可以使用 || 操作符来连接两个或多个字符串。

语法

plaintext 复制代码
expr || expr [|| expr ...]

操作的结果始终为字符串。如果操作数是数字,它在连接之前会被隐式转换为字符串。

如果操作数为 NULL,在连接中将被视为空字符串''。如果所有操作数都为 NULL,则结果为 NULL。

示例

| 拼接 | 结果 | 结果类型 |

| 'a' %%||%% 'b' %%||%% 'c' | 'abc' | 字符串 |

| 'a' %%||%% 1 %%||%% 'c' | 'a1c' | 字符串 |

| 'a' %%||%% NULL %%||%% 'c' | 'ac' | 字符串 |

| NULL %%||%% NULL | NULL | 字符串 |

即时SQL转换

Hive不支持 || 操作符,因此PL/HQL在SQL SELECT语句中会自动转换为[[concat|CONCAT]]函数。

兼容性

支持的数据库系统包括 Oracle、IBM DB2、Teradata、PostgreSQL 和 Netezza。

版本

HPL/SQL 0.1

参见

  • [CONCAT 函数](#CONCAT 函数)(链接到 CONCAT 函数文档)
相关推荐
yuanbenshidiaos36 分钟前
【数据挖掘】数据仓库
数据仓库·笔记·数据挖掘
桃林春风一杯酒2 小时前
HADOOP_HOME and hadoop.home.dir are unset.
大数据·hadoop·分布式
B站计算机毕业设计超人7 小时前
计算机毕业设计Hadoop+Spark+DeepSeek-R1大模型民宿推荐系统 hive民宿可视化 民宿爬虫 大数据毕业设计(源码+LW文档+PPT+讲解)
大数据·hadoop·爬虫·机器学习·课程设计·数据可视化·推荐算法
不剪发的Tony老师10 小时前
Apache Hop:开源版本的Kettle
数据仓库·etl
知初~15 小时前
出行项目案例
hive·hadoop·redis·sql·mysql·spark·database
m0_7482359519 小时前
Python大数据可视化:基于Python的王者荣耀战队的数据分析系统设计与实现_flask+hadoop+spider
hadoop·python·flask
B站计算机毕业设计超人1 天前
计算机毕业设计hadoop+spark旅游景点推荐 旅游推荐系统 旅游可视化 旅游爬虫 景区客流量预测 旅游大数据 大数据毕业设计
大数据·hadoop·爬虫·深度学习·机器学习·数据可视化·推荐算法
专注API从业者2 天前
分布式电商系统中的API网关架构设计
大数据·数据仓库·分布式·架构
我要用代码向我喜欢的女孩表白2 天前
hive迁移补数脚本细粒度 表名-分区唯一键
数据仓库·hive·hadoop
隔壁老登2 天前
查询hive指定数据库下所有表的建表语句并生成数据字典
数据库·hive·hadoop