안녕하세요 이번에 다루고자 하는 내용은 sql 쿼리문 중
true / false 조건에 따른 단일 조건 함수에 대해서 작성하고자 합니다.
지난 포스팅은 다중조건인 CASE WHEN문을 사용했었는대요
물론 CASE문만 알고 있어도 단일 조건이 가능합니다.
하지만 다중조건을 알고계시니 추가로 단일조건도 한번 알아볼까 ~ 하네요
참고로 제가 SQL 관련 포스팅에서 다루고 있는
DBMS종류는 MySQL과 ORACLE, 그리고 MSSQL 이렇게 3가지 위주로 다루고 있는대요
단일조건 관련 함수(?)는 ORACLE과 MySQL만 기본함수로 제공 하고 있습니다.
MSSQL의 경우는 그냥 CASE문을 이용하시길...
그럼 2가지 단일 조건문에 대해서 본격적으로 작성하도록 하겠습니다.
DECODE(컬럼,값,'조건이 일치할 경우의 VALUE','조건이 일치하지 않을경우의 VALUE')
오라클의 decode 문법은 위와 같습니다.
위 실행 화면은 임의로 존재하는 MEMBERTABLE이 있는데
이 테이블을보면 PASSWORD 컬럼의 값을 비교 하려고 합니다.
비밀번호가 '1234'일경우 '위험한비밀번호' 아닐경우 '안전한비밀번호' 라는 가상의 조건으로
진행을 해보도록 하겠습니다.
SELECT id,name,password, DECODE(password,'1234','위험한비밀번호','안전한비밀번호') result FROM MEMBERTABLE
위와 같이 작성한후 실행해보도록 하겠습니다.
확인결과 TRUE FASLE의 조건이 정상적으로 이루어 졌습니다.
이어서 MySQL의 IF함수를 알아보도록 하겠습니다.
IF(조건,'조건이 일치할 경우의 VALUE','조건이 일치하지 않을경우의 VALUE')
IF함수는 DECODE함수보다 입력값이 하나가 적습니다.
DECODE함수의 조건은 EQUAL(=) 만 지원하지만
MySQL의 경우 조건문을 첫번째 입력값에 적어줄수있습니다.
MySQL역시 기존에 존재하는 테이블을 아무거나 하나 보도록 하겠습니다.
저같은 경우에는 ORACLE과 동일한 테이블명 + 데이터를 가진 테이블을 보도록 하겠습니다.
이번 MySQL의 조건은 ORACLE이랑은 살짝 다르게 정해보도록 하겠습니다.
가상조건
membertable의 password 컬럼에 들어있는 글자수를 비교하여
4이하일 경우는 '위험한 비밀번호' 4보다 클경우는 ''안전한 비밀번호'라는 결과값을 출력
이라는 조건으로 실행쿼리를 작성해보겠습니다
select id,name,password, IF(length(password) <= 4,'위험한비밀번호','안전한비밀번호') result from membertable
실행결과를 한번 보도록 하겠습니다.
MySQL의 IF 함수를 이용하여 역시 참/거짓 조건에 맞추어 결과값이 result 컬럼에 정상적으로 출력되었습니다.
이로써 단일조건과 다중조건에 대해서 모두 알아보았습니다.
다중조건이 궁금하신 분은 아래 링크를 참고해주세요 ^^
2014/10/08 - [코드저장소/sql] - ORACLE/MYSQL/MSSQL 관계없이 CASE WHEN THEN ELSE END 사용하기
다음에 조금 더 좋은 글로 찾아뵙겠습니다!!
by 개발로짜
MySQL과 MSSQL의 시퀀스생성 및 초기화 하는방법에 대해서 알아보도록 하자 (0) | 2014.10.14 |
---|---|
MySQL- GROUP_CONCAT 함수로 세로로 출력된 결과를 하나의 컬럼에 가로로 출력하기 (0) | 2014.10.13 |
ORACLE/MYSQL/MSSQL 관계없이 CASE WHEN THEN ELSE END 사용하기 (0) | 2014.10.08 |
DBMS별 기존테이블 SELECT해서 새 테이블에 INSERT하여 데이터 일괄처리하기(oracle,mssql,mysql) (4) | 2014.10.08 |
DBMS 별로 (oracle,mysql,mssql) 널값 처리하기 (0) | 2014.10.07 |