返回介绍

Hive 内置运算符 - Hive 教程

发布于 2025-02-22 13:46:39 字数 5651 浏览 0 评论 0 收藏 0

本章介绍 Hive 的内置运算符。在 Hive 有四种类型的运算符:

  • 关系运算符
  • 算术运算符
  • 逻辑运算符
  • 复杂运算符

关系运算符

这些操作符被用来比较两个操作数。下表描述了在 Hive 中可用的关系运算符:

运算符操作描述
A = B所有基本类型如果表达 A 等于表达 B,结果 TRUE ,否则 FALSE。
A != B所有基本类型如果 A 不等于表达式 B 表达返回 TRUE ,否则 FALSE。
A < B所有基本类型TRUE,如果表达式 A 小于表达式 B,否则 FALSE。
A <= B所有基本类型TRUE,如果表达式 A 小于或等于表达式 B,否则 FALSE。
A > B所有基本类型TRUE,如果表达式 A 大于表达式 B,否则 FALSE。
A >= B所有基本类型TRUE,如果表达式 A 大于或等于表达式 B,否则 FALSE。
A IS NULL所有类型TRUE,如果表达式的计算结果为 NULL,否则 FALSE。
A IS NOT NULL所有类型FALSE,如果表达式 A 的计算结果为 NULL,否则 TRUE。
A LIKE B字符串TRUE,如果字符串模式 A 匹配到 B,否则 FALSE。
A RLIKE B字符串NULL,如果 A 或 B 为 NULL;TRUE,如果 A 任何子字符串匹配 Java 正则表达式 B;否则 FALSE。
A REGEXP B字符串等同于 RLIKE.

示例

让我们假设 employee 表由字段:Id, Name, Salary, Designation, 和 Dept 组成,如下图所示。生成一个查询检索员工详细信息 - ID 为 1205。

+-----+--------------+--------+---------------------------+------+
| Id  | Name         | Salary | Designation               | Dept |
+-----+--------------+------------------------------------+------+
|1201 | Gopal        | 45000  | Technical manager         | TP   |
|1202 | Manisha      | 45000  | Proofreader               | PR   |
|1203 | Masthanvali  | 40000  | Technical writer          | TP   |
|1204 | Krian        | 40000  | Hr Admin                  | HR   |
|1205 | Kranthi      | 30000  | Op Admin                  | Admin|
+-----+--------------+--------+---------------------------+------+

以下查询执行检索使用上述表中的雇员的详细信息:

hive> SELECT * FROM employee WHERE Id=1205;

成功执行的查询,能看到以下回应:

+-----+-----------+-----------+----------------------------------+
| ID  | Name      | Salary    | Designation              | Dept  |
+-----+---------------+-------+----------------------------------+
|1205 | Kranthi   | 30000     | Op Admin                 | Admin |
+-----+-----------+-----------+----------------------------------+

下面的查询执行以检索薪水大于或等于 40000 卢比的雇员的详细信息。

hive> SELECT * FROM employee WHERE Salary>=40000;

成功执行的查询,能看到以下回应:

+-----+------------+--------+----------------------------+------+
| ID  | Name       | Salary | Designation                | Dept |
+-----+------------+--------+----------------------------+------+
|1201 | Gopal      | 45000  | Technical manager          | TP   |
|1202 | Manisha    | 45000  | Proofreader                | PR   |
|1203 | Masthanvali| 40000  | Technical writer           | TP   |
|1204 | Krian      | 40000  | Hr Admin                   | HR   |
+-----+------------+--------+----------------------------+------+

算术运算符

这些运算符支持的操作数各种常见的算术运算。所有这些返回数字类型。下表描述了在 Hive 中可用的算术运算符:

运算符操作描述
A + B所有数字类型A 加 B 的结果
A - B所有数字类型A 减去 B 的结果
A * B所有数字类型A 乘以 B 的结果
A / B所有数字类型A 除以 B 的结果
A % B所有数字类型A 除以 B.产生的余数
A & B所有数字类型A 和 B 的按位与结果
A | B所有数字类型A 和 B 的按位或结果
A ^ B所有数字类型A 和 B 的按位异或结果
~A所有数字类型A 按位非的结果

示例

下面的查询相加两个数字,20 和 30。

hive> SELECT 20+30 ADD FROM temp;

在成功执行查询后,能看到以下回应:

+--------+
|   ADD  |
+--------+
|   50   |
+--------+

逻辑运算符

运算符是逻辑表达式。所有这些返回 TRUE 或 FALSE。

运算符操作描述
A AND BbooleanTRUE,如果 A 和 B 都是 TRUE,否则 FALSE。
A && Bboolean类似于 A AND B.
A OR BbooleanTRUE,如果 A 或 B 或两者都是 TRUE,否则 FALSE。
A || Bboolean类似于 A OR B.
NOT AbooleanTRUE,如果 A 是 FALSE,否则 FALSE。
!Aboolean类似于 NOT A.

示例

下面的查询用于检索部门是 TP 并且工资超过 40000 卢比的员工详细信息。

hive> SELECT * FROM employee WHERE Salary>40000 && Dept=TP;

成功执行查询后,能看到以下回应:

+------+--------------+-------------+-------------------+--------+
| ID   | Name         | Salary      | Designation       | Dept   |
+------+--------------+-------------+-------------------+--------+
|1201  | Gopal        | 45000       | Technical manager | TP     |
+------+--------------+-------------+-------------------+--------+

复杂的运算符

这些运算符提供一个表达式来接入复杂类型的元素。

运算符操作描述
A[n]A 是一个数组,n 是一个 int它返回数组 A 的第 n 个元素,第一个元素的索引 0。
M[key]M 是一个 Map<K, V> 并 key 的类型为 K它返回对应于映射中关键字的值。
S.xS 是一个结构它返回 S 的 s 字段

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文