返回介绍

Hive 操作符

发布于 2024-06-23 16:10:22 字数 6959 浏览 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 为 1025 的详细信息。

  1. +-----+--------------+--------+---------------------------+------+
  2. | Id | Name | Salary | Designation | Dept |
  3. +-----+--------------+------------------------------------+------+
  4. |1201 | Gopal | 45000 | Technical manager | TP |
  5. |1202 | Manisha | 45000 | Proofreader | PR |
  6. |1203 | Masthanvali | 40000 | Technical writer | TP |
  7. |1204 | Krian | 40000 | Hr Admin | HR |
  8. |1205 | Kranthi | 30000 | Op Admin | Admin|
  9. +-----+--------------+--------+---------------------------+------+

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

  1. hive> SELECT * FROM employee WHERE Id=1205;

成功执行的查询,能看到以下结果:

  1. +-----+-----------+-----------+----------------------------------+
  2. | ID | Name | Salary | Designation | Dept |
  3. +-----+---------------+-------+----------------------------------+
  4. |1205 | Kranthi | 30000 | Op Admin | Admin |
  5. +-----+-----------+-----------+----------------------------------+

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

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

成功执行的查询,能看到以下结果:

  1. +-----+------------+--------+----------------------------+------+
  2. | ID | Name | Salary | Designation | Dept |
  3. +-----+------------+--------+----------------------------+------+
  4. |1201 | Gopal | 45000 | Technical manager | TP |
  5. |1202 | Manisha | 45000 | Proofreader | PR |
  6. |1203 | Masthanvali| 40000 | Technical writer | TP |
  7. |1204 | Krian | 40000 | Hr Admin | HR |
  8. +-----+------------+--------+----------------------------+------+

算术运算符

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

hive算术运算符

示例

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

  1. hive> SELECT 20+30 ADD FROM temp;

在成功执行查询后,能看到以下结果:

  1. +--------+
  2. | ADD |
  3. +--------+
  4. | 50 |
  5. +--------+

逻辑运算符

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

hive逻辑运算符

示例

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

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

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

  1. +------+--------------+-------------+-------------------+--------+
  2. | ID | Name | Salary | Designation | Dept |
  3. +------+--------------+-------------+-------------------+--------+
  4. |1201 | Gopal | 45000 | Technical manager | TP |
  5. +------+--------------+-------------+-------------------+--------+

复杂的运算符

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

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

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

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

发布评论

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