여러분이 사용하고 계신 브라우저는 HTML5를 지원하지 않기 때문에 몇몇 요소가 제대로 보이도록 JScript를 사용하고 있습니다. 하지만 여러분의 브라우저 설정에서 스크립트 기능이 꺼져있으므로, 현재 페이지를 제대로 확인하시려면 스크립트 기능을 켜주셔야 합니다. SQL - 연산자
SQL – 연산자
2년전 작성
1년전 수정

연산자

산술 연산자

산술 연산자 설명
+
:
더하기. 추가하기
:
빼기. 차감하기
*
:
곱하기
/
:
나누기
%
:
나눈 후 나머지

비트 연산자

인수는 정수 데이터 형식 범주에 속하는 데이터 형식, bit, binary 또는 varbinary 데이터 형식 중 하나인 유효한 식이다.
expression은 비트 연산의 이진 숫자로 처리된다.

결과 값은 입력 값이 int이면 int다.
결과 값은 입력 값이 smallint이면 smallint다.
결과 값은 입력된 값이 tinyint 또는 bit인 경우 tinyint다.

&

두 정수 값 간에 비트 논리 AND 연산을 수행한다.

& 비트 연산자는 두 식 간에 비트 논리 AND를 수행하고 양쪽 식에서 해당 비트를 취한다.
결과의 비트는 입력 식에 있는 양쪽 비트(확인 중인 현재 비트)의 값이 1이면 1로 설정되고 그렇지 않으면 0으로 설정된다.

왼쪽과 오른쪽 식의 정수 데이터 형식이 서로 다르면(예: 왼쪽 식은 smallint이고 오른쪽 식은 int임) 더 작은 데이터 형식의 인수가 더 큰 데이터 형식으로 변환된다.
이 경우에 smallint식이 int로 변환된다.

구문
expression & expression
값을 저장하기 위해 int 데이터 형식을 사용하여 테이블을 만들고 두 값을 한 행에 삽입
CREATE TABLE bitwise (   
  a_int_value INT NOT NULL,  
  b_int_value INT NOT NULL);  
GO  
INSERT bitwise VALUES (170, 75);  
GO
a_int_value와 b_int_value 열 간에 비트 AND를 수행
SELECT a_int_value & b_int_value  
FROM bitwise;  
GO

기본 예시
———–
10

(1 row(s) affected)


170의 이진 표현(a_int_value 또는 A)은 0000 0000 1010 1010이다.
75의 이진 표현(b_int_value 또는 B)은 0000 0000 0100 1011이다.
이 두 값에 대해 비트 AND 연산을 수행하면 이진수로 0000 0000 0000 1010이 산출되며 십진수로는 10이다.

|

이진 식으로 변환되는 두 개의 지정된 정수 값 간에 비트 논리 OR 연산을 수행한다.

비트 | 연산자는 양쪽 식에 해당 비트를 취하면서 두 식 간에 비트 논리 OR를 수행한다.
결과의 비트는 입력 식의 두 비트(확인 중인 현재 비트) 중 하나 또는 둘 모두의 값이 1이면 1로 설정된다.
입력 식에 값이 1인 비트가 없으면 결과의 비트는 0으로 설정된다.

왼쪽과 오른쪽 식의 정수 데이터 형식이 서로 다르면(예: 왼쪽 식은 smallint이고 오른쪽 식은 int임) 더 작은 데이터 형식의 인수가 더 큰 데이터 형식으로 변환된다.
이 예제에서는 smallint식이 int로 변환된다.

구문
expression | expression
원래 값을 표시하도록 int 데이터 형식의 테이블을 만들고 테이블을 하나의 행에 삽입
CREATE TABLE bitwise (  
  a_int_value INT NOT NULL,  
  b_int_value INT NOT NULL);  
GO  
INSERT bitwise VALUES (170, 75);  
GO
a_int_value 및 b_int_value 열에 대해 비트 OR를 수행
SELECT a_int_value | b_int_value  
FROM bitwise;  
GO

기본 예시
———–
235

(1 row(s) affected)


170(a_int_value 또는 아래 A)의 이진 표현은 0000 0000 1010 1010이다.
75(b_int_value 또는 아래 B)의 이진 표현은 0000 0000 0100 1011이다.
이 두 값에 비트 OR 연산을 수행하면 10진수 235에 해당되는 이진 결과 0000 0000 1110 1011이 산출된다.

^

두 정수 값 사이에 배타적 비트 OR 연산을 수행한다.

^ 비트 연산자는 양쪽 연산에 해당 비트를 받아서 두 식 간에 배타적 비트 논리 OR를 수행한다.
결과 비트는 입력 식에 있는 두 비트(확인 중인 현재 비트) 중 하나의 값이 1이면 1로 설정된다.
양쪽 비트 값이 모두 0 또는 1이면 결과 비트는 0으로 처리된다.

왼쪽과 오른쪽 식의 정수 데이터 형식이 서로 다르면(예: 왼쪽 식은 smallint이고 오른쪽 식은 int임) 더 작은 데이터 형식의 인수가 더 큰 데이터 형식으로 변환된다.
이 경우에 smallint식이 int로 변환된다.

구문
expression ^ expression
원래 값을 저장하기 위해 int 데이터 형식을 사용하여 원래 값을 저장하는 테이블을 만들고 한 행에 두 개의 값을 삽입
CREATE TABLE bitwise (   
  a_int_value INT NOT NULL,  
  b_int_value INT NOT NULL);
GO  
INSERT bitwise VALUES (170, 75);  
GO
a_int_value 및 b_int_value 열에 배타적 비트 OR를 수행
SELECT a_int_value ^ b_int_value  
FROM bitwise;  
GO

기본 예시
———–
225

(1 row(s) affected)


170의 이진 표현(a_int_value 또는 A)은 0000 0000 1010 1010이다.
75의 이진 표현(b_int_value 또는 B)은 0000 0000 0100 1011이다.
이러한 두 값에 배타적 비트 OR 연산을 수행하면 결과는 이진수 0000 0000 1110 0001이며 십진수로는 225다.

비교 연산자

비교 연산자 설명
=
:
앞의 값과 뒤의 값이 같다.
>
:
앞의 값이 뒤의 값보다 크다.
<
:
앞의 값이 뒤의 값보다 작다.
>=
:
앞의 값이 뒤의 값과 같거나 크다.
<=
:
앞의 값이 뒤의 값과 같거나 작다.
<>
:
앞의 값과 뒤의 값이 다르다.

복합 연산자

복합 연산자 설명
+=
:
앞의 값에 뒤의 값을 더하고 앞의 값을 연산 결과로 설정한다.
-=
:
앞의 값에서 뒤의 값을 빼고 앞의 값을 연산 결과로 설정한다.
*=
:
앞의 값에 뒤의 값을 곱하고 앞의 값을 연산 결과로 설정한다.
/=
:
앞의 값에 뒤의 값을 나누고 앞의 값을 연산 결과로 설정한다.
%=
:
앞의 값에 뒤의 값을 나누고 앞의 값을 나머지로 설정한다.
&=
:
비트 AND를 수행하고 앞의 값을 연산 결과로 설정한다.
^=
:
배타적 비트 OR를 수행하고 앞의 값을 연산 결과로 설정한다.
|=
:
비트 OR를 수행하고 원래 값을 앞의 결과로 설정한다.

논리 연산자

사용된 코드 설명
ALL
:
모든 하위 쿼리 값이 조건을 충족하는 경우 TRUE를 반환한다.
AND
:
AND로 구분된 모든 조건이 충족되면 TRUE를 반환한다.
ANY
:
하위 쿼리 값 중 하나라도 조건을 충족하는 경우 TRUE를 반환한다.
BETWEEN
:
피연산자가 비교 범위 내에 있으면 TRUE를 반환한다.
EXISTS
:
하위 쿼리가 하나 이상의 레코드를 반환하는 경우 TRUE를 반환한다.
IN
:
피연산자가 표현식 목록 중 하나와 같으면 TRUE를 반환한다.
LIKE
:
피연산자가 패턴과 일치하는 경우 TRUE를 반환한다.
NOT
:
조건이 TRUE가 아닌 경우 레코드를 표시한다.
OR
:
OR로 구분된 조건 중 하나라도 TRUE인 경우 TRUE를 반환한다.
SOME
:
하위 쿼리 값 중 하나라도 조건을 충족하는 경우 TRUE를 반환한다.

참고

Mingg`s Diary
밍구
밍구
공부 목적 블로그