메뉴 건너뛰기

조회 수 9690 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

프로젝트를 진행할 때 SQL 쿼리를 작성하다보면 'WHERE 1 = 1' 이라는 것을 자주 보게 됩니다. 사실, 의미없이 'WHERE 1 = 1'이라는 구문을 사용하시는 분들이 있어서 깔끔한 걸 추구하는 저로서는 가끔 1 = 1 이라는 부분을 지워버리는데요. 이것을 잘 사용하면 조건절(WHERE)을 편리하게 사용할 수 있어서 편리합니다.

 


사용법에 대해 간단하게 알아보겠습니다.

 

1. AND 구문에서는 WHERE 1 = 1 사용하자.

만약에, 'WHERE 1=1'이 없다면 if 조건절 안에 WHERE를 넣어야 할지 AND를 넣어야할지 알 수 없습니다.
'WHERE 1 = 1'을 사용하게 되면 아래 조건절에 무조건 AND를 넣으면 되는 겁니다.

	SELECT *
	  FROM NAME_LIST
 	 WHERE 1 = 1
	 #if(!$name.equals(''))
		AND NAME = '$name'
	 #end
	 #if(!$age.equals(''))
		AND AGE = '$age'
	 #end


 

2. OR 구문에서는 WHERE 1 = 0을 사용하자.

위 1번과는 달리 OR 구문에서는 WHERE 1 = 0을 사용해야 합니다.
결과값이 아무것도 없는 상태에서 OR 구문으로 결과를 하나씩 하나씩 추가해 나가야 하니까요.

	SELECT *
	  FROM NAME_LIST
 	 WHERE 1 = 0
	 #if(!$name.equals(''))
		OR NAME = '$name'
	 #end
	 #if(!$age.equals(''))
		OR AGE = '$age'
	 #end

 

 

사실 알고보면 별거 아닌 간단한 기능이지만, 이걸 모르면 WHERE절 밑의 IF절이 복잡해지게 되는거죠.

#if where name = '$name' #end
#if and name = '$name' #end

이 둘 중에 무엇을 써야할지 일일이 조건을 따져서 코딩을 하게 되면 코딩이 길어지게 됩니다.
사실, 꼼수로서는 실전에서 굉장히 유용하게 잘 사용되는 방법입니다.


List of Articles
번호 제목 날짜 조회 수
21 TOAD 에서 SQL Builder 을 사용하여 DML 문서 작성을 자동화 해본다 file 2016.08.30 7567
20 Toad 사용시 캐릭터 인코더 UTF-8 로 변경하기 file 2016.08.30 10168
19 Oracle 에서 NVL, NVL2 함수 사용하는 예제 2016.08.30 8395
18 rownum 으로 범위지정을 해주고 싶을 때 2016.08.30 8680
17 Oracle 시퀀스 생성, 추가, 삭제 file 2016.08.30 8220
16 TOAD 에서 Edit 를 통해 sql문을 작성할때 참고해야할 View file 2016.08.30 7521
15 UNION ALL 과 ORDER BY 섞어서 쓰기 2016.08.30 9967
14 오라클(Oracle) 대용량 데이터 토드(Toad)를 이용해서 넣기 file 2016.08.30 8098
13 간단한 쿼리로 일련번호 쉽게 넣기 - ROWNUM 사용 file 2016.08.29 9587
12 Oracle에서 ORA-28000: 계정이 잠금되었습니다. - 해결 방법 file 2016.08.29 7376
11 WHERE절에서 Null 값 비교하기 file 2016.08.29 9400
10 Oracle에서 Foreign Key가 걸려있는 컬럼값 업데이트(update) 하기 file 2016.08.29 9228
9 Oracle에서 사용자가 생성한 모든 Table, View를 삭제하는 쿼리 만들기 file 2016.08.29 7522
8 Oracle에서 세자리 콤마 찍기 file 2016.08.29 11798
7 Merge into를 이용해서 insert나 update를 자동으로 실행하자. 2016.08.29 7749
» 조건절에 WHERE 1=1, WHERE 1=0 사용하여 쿼리 간편하게 사용하기 file 2016.08.29 9690
5 Oracle에서 중복 조인을 피하기 위한 Update 방법 (MERGE 사용) 2016.08.29 8199
4 단일행을 다중 row로 분리, 다중 row 결과를 단일행으로 연결하는 방법 2016.08.29 9470
3 WITH문으로 쿼리를 임시테이블이나 View처럼 사용하자. 2016.08.29 8421
2 Oracle 저장 프로시저 샘플 2016.08.29 7283
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved