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 函数文档)
相关推荐
tsyjjOvO4 小时前
SpringMVC 从入门到精通
数据仓库·hive·hadoop
Francek Chen9 小时前
【大数据存储与管理】分布式数据库HBase:05 HBase运行机制
大数据·数据库·hadoop·分布式·hdfs·hbase
zzzzzwbetter9 小时前
Hadoop完全分布式部署-Master的NameNode以及Slaver2的DataNode未启动
大数据·hadoop·分布式
weixin_4493108411 小时前
ETL转换和数据写入小满OKKICRM的技术细节
数据仓库·php·etl
IvanCodes12 小时前
Hive IDE连接及UDF实战
ide·hive·hadoop
yumgpkpm13 小时前
华为昇腾910B 开源软件GPUStack的介绍(Cloudera CDH、CDP)
人工智能·hadoop·elasticsearch·flink·kafka·企业微信·big data
lifewange1 天前
Hive数据库
数据库·hive·hadoop
五月天的尾巴2 天前
hive数据库模糊查询表名
hive·查询表名
蓝魔Y2 天前
hive—1.1、执行优化
hive
快乐非自愿3 天前
OpenClaw 生态适配:Hadoop/Hive 技能现状与企业级集成方案
大数据·hive·hadoop·分布式·openclaw