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는 NULL입니다. 모든 유형 표현식 A가 NULL로 평가되면 TRUE, 그렇지 않으면 FALSE입니다.
A는 NULL이 아닙니다. 모든 유형 표현식 A가 NULL로 평가되면 FALSE, 그렇지 않으면 TRUE입니다.
A LIKE B 문자열 문자열 패턴 A가 B와 일치하면 TRUE, 그렇지 않으면 FALSE.
A RLIKE B 문자열 A 또는 B가 NULL이면 NULL, A의 하위 문자열이 Java 정규식 B와 일치하면 TRUE, 그렇지 않으면 FALSE입니다.
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의 비트 AND 결과를 제공합니다.
A | 비 모든 숫자 유형 A와 B의 비트 단위 OR 결과를 제공합니다.
A ^ B 모든 숫자 유형 A와 B의 비트 별 XOR 결과를 제공합니다.
~ A 모든 숫자 유형 A의 비트 NOT 결과를 제공합니다.

다음 쿼리는 20과 30이라는 두 숫자를 더합니다.

hive> SELECT 20+30 ADD FROM temp;

쿼리를 성공적으로 실행하면 다음 응답이 표시됩니다.

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

논리 연산자

연산자는 논리식입니다. 모두 TRUE 또는 FALSE를 반환합니다.

연산자 피연산자 기술
A와 B 부울 A와 B가 모두 TRUE이면 TRUE이고, 그렇지 않으면 FALSE입니다.
A && B 부울 A 및 B와 동일합니다.
A 또는 B 부울 A 또는 B 또는 둘 다 TRUE이면 TRUE이고, 그렇지 않으면 FALSE입니다.
A || 비 부울 A OR B와 동일합니다.
아님 부울 A가 FALSE이면 TRUE이고, 그렇지 않으면 FALSE입니다.
!ㅏ 부울 NOT A와 동일합니다.

다음 쿼리는 부서가 TP이고 급여가 Rs 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 [키] M은 Map <K, V>이고 키는 K 유형입니다. 맵의 키에 해당하는 값을 반환합니다.
Sx S는 구조체입니다. S의 x 필드를 반환합니다.