SQL

[패스트캠퍼스] SQL 강의 1주차 (Day4); WHERE, NOT, AND, OR, BETWEEN, IN, LIKE, IS NULL,

maencoli 2023. 3. 7. 12:45
SELECT [컬럼이름]
FROM [테이블 이름]
WHERE [컬럼 이름] BETWEEN [조건1] AND [조건2];

조건에 맞는 데이터 가져오기 WHERE

가져올 데이터의 조건 지정

  • WHERE 조건식 
  • 조건이 True가 되는 row 만 선택
SELECT [컬럼이름]
FROM [테이블 이름]
WHERE 조건식;
  • 보통은 '연산자'를 사용해서 조건식 작성 
  • 원하는 데이터 조건이 True가 되게끔 조건식 작성
  • True 값은 1, False 값은 0으로 표현
  • 종류 : 비교 연산자/ 논리 연산자/ 기타 주요 연산자

비교 연산자 (=,<, >)

연산자 활용 의미
A = B A 와 B가 같다
!=  A != B A와 B가 같지 않다
> A > B A가 B보다 크다
>= A >= B A가 B보다 크거나 같다
< A < B A가 B보다 작다
<= A <= B A가 B보다 작거나 같다

 

논리 연산자 NOT, AND, OR

연산자 활용 의미
AND A AND B A와 B 모두 True이면 True
OR A OR B A와 B 둘 중 하나 이상 True이면 True
NOT  NOT A A 가 아니면 True

기타 주요 연산자 BETWEEN, IN

BETWEEN

특정 범위 내의 데이터를 선택할 때 사용하는 연산자

  • [컬럼이름] BETWEEN A AND B 형식으로 사용
  • 해당 컬럼 값이 A 와 B 사이에 포함되는 값을 가진 row만 선택 (A <= 컬럼 값 <= B)
  • [컬럼이름] BETWEEN A AND B쿼리는 A <= [컬럼이름] AND [컬럼이름] <= B와 동일
SELECT [컬럼이름]
FROM [테이블이름]
WHERE [컬럼이름] BETWEEN [조건1] AND [조건2];

IN

목록 내 포함되는 데이터를 선택할 때 사용하는 연산자

  • [컬럼이름] IN (A, B, ..., C)형식으로 사용
  • 해당 컬럼의 값이 '()'내의 값에 포함되는 값을 가진 row만 선택
  • [컬럼이름] IN (A, B)쿼리는 [컬럼이름] = A OR [컬럼이름] = B와 동일함
  • 목록에 넣을 값이 여러 개일때, OR 연산자보다 표현/이해가 쉬움... 
SELECT [컬럼이름]
FROM [테이블 이름]
WHERE [컬럼이름] IN ([조건1], [조건2], ...);

 

문자 데이터 LIKE

특정 문자열이 포함된 데이터를 선택하는 연산자

  • [컬럼이름] LIKE [검색할 문자열] 형식
  • 해당 컬럼 값이 [검색할 문자열]을 포함하고 있는 row 만 선택
  • [검색할 문자열] 내 와일드 카드를  사용하여 검색 조건을구제척으로 표현 가능
와일드카드 의미
% 0개 이상의 문자
_ 1개의 문자
SELECT [컬럼 이름]
FROM [테이블 이름]
WHERE [컬럼 이름] LIKE [검색할 문자열];

NULL 데이터

  • 데이터 값이 존재하지 않는다는 표현
  • 0이나 공백이 아닌, 알 수 없는 값

IS NULL

데이터가 NULL인지 아닌지를 확인

  • [칼럼이름] IS NULL
  • 해당 칼럼이 NULL인 row 만 선택
  • NULL이 아닌 데이터를 검색하고 싶으면, IS NOT NULL 사용
  • [칼럼이름] = NULL 또는 [칼럼이름] != NULL은 사용  안함!!!
SELECT [칼럼이름]
FROM [테이블이름]
WHERE [칼럼 이름] IS NULL;