Hive 内置操作符

Hive 内置操作符

这章介绍了Hive的内置操作符。Hive有四种类型的操作符:

  • 关系操作符
  • 算术操作符
  • 逻辑操作符
  • 复杂操作符

阅读更多:Hive 教程

关系操作符

这些操作符用于比较两个操作数。下表列出了Hive中可用的关系操作符:

操作符 操作数 描述
A = B 所有原始类型 如果表达式A等于表达式B,则为TRUE;否则为FALSE。
A != B 所有原始类型 如果表达式A不等于表达式B,则为TRUE;否则为FALSE。
A < B 所有原始类型 如果表达式A小于表达式B,则为TRUE;否则为FALSE。
A <= B 所有原始类型 如果表达式A小于或等于表达式B,则为TRUE;否则为FALSE。
A > B 所有原始类型 如果表达式A大于表达式B,则为TRUE;否则为FALSE。
A >= B 所有原始类型 如果表达式A大于或等于表达式B,则为TRUE;否则为FALSE。
A IS NULL 所有类型 如果表达式A求值为NULL,则为TRUE;否则为FALSE。
A IS NOT NULL 所有类型 如果表达式A求值为NULL,则为FALSE;否则为TRUE。
A LIKE B 字符串 如果字符串模式A匹配B,则为TRUE;否则为FALSE。
A RLIKE B 字符串 如果A或B为NULL,则为NULL;如果A的任何子字符串与Java正则表达式B匹配,则为TRUE;否则为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 |
+-----+-----------+-----------+----------------------------------+

执行以下查询以检索工资大于或等于 Rs 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 所有数字类型 给出将 B 除以 A 的结果。
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 B 布尔值 如果 A 和 B 同时为 TRUE,则为 TRUE;否则为 FALSE。
A && B 布尔值 与 A AND B 相同。
A OR B 布尔值 如果 A 或 B 或两者都为 TRUE,则为 TRUE;否则为 FALSE。
A B| 布尔值| 与 A OR B 相同。
NOT A 布尔值 如果 A 为 FALSE,则为 TRUE;否则为 FALSE。
!A 布尔值 与 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.x S是一个结构体 返回S的x字段。

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程