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字段。 |