메뉴 건너뛰기

조회 수 9617 추천 수 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

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


  1. No Image 30Aug
    by
    2016/08/30 Views 9899 

    UNION ALL 과 ORDER BY 섞어서 쓰기

  2. 데이터베이스 백업하기 ( import : 가져오기 , export : 내보내기 )

  3. 오라클 백업 및 복구(Export, Import)

  4. 오라클11g DB 생성

  5. No Image 11Sep
    by
    2016/09/11 Views 9663 

    oracle db 백업(full)

  6. 조건절에 WHERE 1=1, WHERE 1=0 사용하여 쿼리 간편하게 사용하기

  7. 다른 버전의 오라클 import, export 하기

  8. 간단한 쿼리로 일련번호 쉽게 넣기 - ROWNUM 사용

  9. No Image 29Aug
    by
    2016/08/29 Views 9403 

    단일행을 다중 row로 분리, 다중 row 결과를 단일행으로 연결하는 방법

  10. PL/SQL에서 자바(Java) 클래스(Class), 함수 실행 방법

  11. WHERE절에서 Null 값 비교하기

  12. ORA-01652 128(으)로 테이블 공간 ***에서 임시 세그먼트를 확장할 수 없습니다.

  13. Oracle에서 Foreign Key가 걸려있는 컬럼값 업데이트(update) 하기

  14. No Image 08Dec
    by
    2016/12/08 Views 9089 

    [Oracle|오라클] 한글 초성 검색 함수

  15. oracle 특수문자 입력시 Substitution Variable 변수치환을 없애는 방법

  16. No Image 08Dec
    by
    2016/12/08 Views 8973 

    ORA-39142 덤프 버전이 틀려서 넣지 못할 때

  17. Oracle 에서 테이블과 리소스의 존재 여부를 알아보는 쿼리

  18. 오라클 12c (Oracle) 에서 테스트를 위해 샘플 스키마 설치하기

  19. No Image 12Sep
    by
    2016/09/12 Views 8925 

    시퀀스 초기화 프로시저

  20. No Image 08Dec
    by
    2016/12/08 Views 8912 

    sqlplus에서 Ampersand나 특수 문자를 갖는 데이타를 insert하는 방법 sqlplus 데이터 insert 입력값 요구

Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved