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 String 如果字符串模式A与B匹配,则为TRUE,否则为FALSE。
    A RLIKE B String 如果A或B为NULL,则为NULL;如果A的任何子字符串与Java正则表达式B匹配,则为TRUE;否则为FALSE。
    A REGEXP B String 与RLIKE相同。
    - 让我们假设员工表由名为Id,姓名,薪金,指定和部门的字段组成,如下所示。生成查询以检索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 所有数字类型 给出将B除以A的结果。
    A % B 所有数字类型 给出由A除以B产生的余数。
    A & B 所有数字类型 给出A和B的按位与的结果。
    A | B 所有数字类型 给出A和B的按位或的结果。
    A ^ B 所有数字类型 给出A和B的按位XOR(异或)结果。
    ~A 所有数字类型 给出A的按位NOT的结果。
    - 以下查询将两个数字相加,即20和30。
    
    hive> SELECT 20+30 ADD FROM temp;
    
    成功执行查询后,您将看到以下响应:
    
    +--------+
    |   ADD  |
    +--------+
    |   50   |
    +--------+
    
  • 逻辑运算符

    运算符是逻辑表达式。它们全部返回TRUE或FALSE。
    操作符 操作数 描述
    A AND B 布尔值 如果A和B均为TRUE,则为TRUE,否则为FALSE。
    A && B 布尔值 与A和B相同。
    A OR B 布尔值 如果A或B或两者均为TRUE,则为TRUE,否则为FALSE。
    A || B 布尔值 与A或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是一个整数 它返回数组A中的第n个元素。第一个元素的索引为0。
    M[key] M 是Map <K,V>并且键的类型为K 它返回对应于映射中键的值。
    S.x S 是一个结构 它返回S的x字段。