안녕하세요 이번에 다루고자 하는 내용은 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 |
안녕하세요 개발로짜입니다 ^^
이번포스팅은 DB 조건문을 주었을 경우 사용하는 CASE 문인대요
제목에서 아시다시피 주로사용하는 Oracle 이나 MySQL, MS-SQL 모두 적용 가능한 다중 조건문입니다.
일반 개발에서 사용하는
switch 문이나 if문과 비슷하다고 보시면 되실거예요
오라클과 MySQL에는 참 또는 거짓을 기술할수 있는...
쉽게말해서 if else 문이 별도로 존재하는데
요건 다음 포스팅때 작성하도록 하겠습니다.
그럼 우선적으로 사용 구문법부터 보시겠습니다.
CASE WHEN 조건 THEN '대체값' WHEN 조건 THEN '대체값' ELSE 'WHEN 조건에 해당안될경우의 기본값' END
사용문법은 위와같습니다.
말씀드린 switch 문이랑 if 문이랑 비슷하죠?
그럼 어짜피 모든 DBMS에 적용가능한 문법이니
아무거나 정해서 CASE문을 적용해보도록 하겠습니다.
우선 저는 MySQL DB로 적용해볼까 합니다.
아무 테이블에 존재하는 데이터를 변경해보도록 하겠습니다.
저같은 경우 member 테이블의 데이터들을 조회한 결과
상단처럼 member_name 컬럼에 중복값이 들어가 있습니다.
'이순신','홍길동'
한글을 조건절에 들어가는것은 좋지 않습니다만
샘플삼아 작성하는것이므로 ...
member 테이블의 member_name의 결과값이 '이순신'이면 '중복1' , '홍길동'이면 '중복2', 그외에는 '중복아님' 출력
위 조건으로 실행쿼리를 작성해보도록 하겠습니다.
SELECT member_name, CASE WHEN member_name = '이순신' THEN '중복1' WHEN member_name = '홍길동' THEN '중복2' ELSE '중복아님' END AS result FROM member
위와같이 정상적으로 CASE문이 사용하여 결과값이 나왔습니다!!!
MySQL이 아니여도 MS-SQL 또는 오라클에서도 구문을 동일 하게 사용할 수 있답니다~
by 개발로짜
MySQL과 MSSQL의 시퀀스생성 및 초기화 하는방법에 대해서 알아보도록 하자 (0) | 2014.10.14 |
---|---|
MySQL- GROUP_CONCAT 함수로 세로로 출력된 결과를 하나의 컬럼에 가로로 출력하기 (0) | 2014.10.13 |
쿼리의 조건문 사용시 oracle에는 decode가있고 mysql에는 if가 있다 (0) | 2014.10.09 |
DBMS별 기존테이블 SELECT해서 새 테이블에 INSERT하여 데이터 일괄처리하기(oracle,mssql,mysql) (4) | 2014.10.08 |
DBMS 별로 (oracle,mysql,mssql) 널값 처리하기 (0) | 2014.10.07 |
안녕하세요 개발로짜 입니다.
이번에는 기존에 존재하는 테이블들의 데이터들을 다른 테이블로
데이터 이관하는 작업에 필요한 명령문에 대하여 설명 드리고자 합니다.
SELECT INSERT문이라고 하는대요(?)
DBMS의 종류들은 MySQL, MS-SQL , Oracle 이 세가지에 대하여
포스팅 하도록 하겠습니다.
각 DBMS별 SELECT INSERT 명령문을 먼저 보시도록 하겠습니다.
INSERT 신규테이블명(컬럼1,컬럼2) SELECT 컬럼1,컬럼2 FROM 기존테이블 WHERE 조건절(해당부분은 선택형)
MSSQL의 경우는 2가지 SEELCT INSERT 구문을 사용할 수 있습니다.
첫번째로는 MySQL과 동일한
INSERT 신규테이블명(컬럼1,컬럼2) SELECT 컬럼1,컬럼2 FROM 기존테이블 WHERE 조건절(역시 해당부분 선택형)
이며 두번째로
SELECT 컬럼1,컬럼2 INTO 신규테이블 FROM 기존테이블 WHERE 조건절(선택형)
위와같이 줄 수 있습니다.
하지만 첫번째와 두번째 구문의 차이점이라고 한다면
첫번째 구문의 경우는 신규테이블이 존재하는 상태에서 기존데이터들을 INSERT하는 형식
두번째 구문은 VIEW생성을 하는거와 동일하게 신규테이블이 없는 상태에서 INSERT하는 형식
SELECT INTO FROM 구문일 경우
INTO에 선언해준 테이블이 자동으로 생성되어 데이터들이 일괄등록 해주는 것이죠.
INSERT INTO 신규테이블(컬럼1,컬럼2) SELECT 컬럼1,컬럼2 FROM 기존테이블 WHERE 조건절(선택형)
오라클의 경우 MySQL,MS-SQL의 INSERT SELECT FROM과 동일하지만
추가적으로 INSERT 다음에 INTO가 들어가야 한다는점~
그렇다면 각 명령어를 이용하여 실행결과를 보도록 하겠습니다.
3가지 DBMS의 공통시나리오는 다음과 같습니다.
기존에 데이터가 존재하는 테이블(BOARD_OLD)의 데이터들을
일괄로 신규로 생성된 테이블(BOARD_NEW)에 INSERT하기
상단 화면처럼 모두 동일한 테이블을 기준으로 각 명령어를 이용하여
우측 BOARD_NEW 테이블에 데이터 INSERT 작업을 하도록 해보겠습니다
위 결과화면에서 보시면 MySQL을 제외한 나머지는 SELECT * <<일괄로 각 컬럼 지정없이
신규테이블에 INSERT를 해주었습니다.
MySQL에서는 아쉽게도 지원을 안해주는거 같더군요 ^^
3가지 DBMS 모두다 정상적으로 SELECT INSERT 구문을 이용하여 한번에 데이터 이관을 해보았습니다.
유용하시길...
by 개발로짜
MySQL과 MSSQL의 시퀀스생성 및 초기화 하는방법에 대해서 알아보도록 하자 (0) | 2014.10.14 |
---|---|
MySQL- GROUP_CONCAT 함수로 세로로 출력된 결과를 하나의 컬럼에 가로로 출력하기 (0) | 2014.10.13 |
쿼리의 조건문 사용시 oracle에는 decode가있고 mysql에는 if가 있다 (0) | 2014.10.09 |
ORACLE/MYSQL/MSSQL 관계없이 CASE WHEN THEN ELSE END 사용하기 (0) | 2014.10.08 |
DBMS 별로 (oracle,mysql,mssql) 널값 처리하기 (0) | 2014.10.07 |