Database/SQL
[SQL] WHERE절 1=1, 1=0 의미
ChrisJang
2020. 11. 10. 11:09
1. AND 구문에서는 WHERE 1 = 1
만약에 'WHERE 1=1'이 없다면 if 조건절 안에 WHERE를 넣어야 할지 AND를 넣어야할지 혼란스럽다.
그러나 'WHERE 1 = 1'을 사용하면 아래 조건절에 AND를 넣어주면된다
SELECT *
FROM skybar
WHERE 1 = 1
#if(!$room.equals(''))
AND room = '$room'
#end
#if(!$alco.equals(''))
AND alco = '$alco'
#end
왜 WHERE 1=1??
① 쿼리 디버깅 시, 주석처리가 편하다.
아래와 같은 쿼리가 있다고 가정하자
위와 같은 커리문에서 잠시 CUSTOMERID = '3'에 주석 처리할때
위와 같은 경우처럼 두번의 주석을 사용해야하는 번거로움이 발생한다.
그러나 WHERE 1=1을 이용하여 보다 편리하게 쿼리 작성이 가능한다
② 동적쿼리에서 특정상황마다 WHERE절을 다르게 작성해줘야 할때 편리하다.
query1 = "SELECT * FROM CUSTOMER "
if(!cusotmerID.equals("") {
query2 = "WHERE CUSTOMERID = '" + customerID + "'"
}
if(!companyName.equals("") {
if(!customerId.equals("") {
query3 = "AND"
} else {
query3 = "WHERE"
}
query4 = "COMPANAYNAME = '" + companayname + "'"
}
위의 커리를 보다 간단하게 쓸수있다.
query1 = "SELECT * FROM CUSTOMER WHERE 1=1 "
if(!cusotmerID.equals("") {
query2 = "AND CUSTOMERID = '" + customerID + "'"
}
if(!companyName.equals("") {
query2 = "AND COMPANYNAME = '" + companyName + "'"
}
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
출처 :