sql에서 where문 작성시.. 궁금한게있어요..

select 문에서 'as'로 컬럼이름을 부여한 것을 where 조건에 넣을 수 없는데 다른 방법이 있을까요??
일단은 where문에 as 전의 case문을 다 적었는데...

아래는 제가 코딩하다가 생긴 예입니다..


select
(CASE WHEN PRIOR_DTIME IS NOT NULL THEN
     (CASE WHEN DATEPART(DW, PRIOR_DTIME) IN (2,3) THEN DATEDIFF(dd,REQ_DTIME,PRIOR_DTIME) -2
      ELSE DATEDIFF(dd,REQ_DTIME,PRIOR_DTIME) END)
WHEN PRIOR_DTIME IS NULL AND COM_DTIME IS NOT NULL THEN
      (CASE WHEN DATEPART(DW, COM_DTIME) IN (2,3) THEN DATEDIFF(dd,REQ_DTIME,COM_DTIME) -2
       ELSE DATEDIFF(dd,REQ_DTIME,COM_DTIME) END)
ELSE NULL END) as PPPP,  --이부분
* FROM CS_CASE

 WHERE

-- 1) 안되는 조건 :
PPPP > 2

-- 2) 되는 방법 : case문 똑같이 다 써주기..
(CASE WHEN PRIOR_DTIME IS NOT NULL THEN
(CASE WHEN DATEPART(DW, PRIOR_DTIME) IN (2,3) THEN DATEDIFF(dd,REQ_DTIME,PRIOR_DTIME) -2 ELSE DATEDIFF(dd,REQ_DTIME,PRIOR_DTIME) END)
WHEN PRIOR_DTIME IS NULL AND COM_DTIME IS NOT NULL THEN
(CASE WHEN DATEPART(DW, COM_DTIME) IN (2,3) THEN DATEDIFF(dd,REQ_DTIME,COM_DTIME) -2 ELSE DATEDIFF(dd,REQ_DTIME,COM_DTIME) END)
ELSE NULL END)
 >2

|

댓글 3개

SELECT * FROM (
select
(CASE WHEN PRIOR_DTIME IS NOT NULL THEN
(CASE WHEN DATEPART(DW, PRIOR_DTIME) IN (2,3) THEN DATEDIFF(dd,REQ_DTIME,PRIOR_DTIME) -2
ELSE DATEDIFF(dd,REQ_DTIME,PRIOR_DTIME) END)
WHEN PRIOR_DTIME IS NULL AND COM_DTIME IS NOT NULL THEN
(CASE WHEN DATEPART(DW, COM_DTIME) IN (2,3) THEN DATEDIFF(dd,REQ_DTIME,COM_DTIME) -2
ELSE DATEDIFF(dd,REQ_DTIME,COM_DTIME) END)
ELSE NULL END) as PPPP,
* FROM CS_CASE

) FROM TMP WHERE PPPP > 2
감사합니다 . select로 묶어주면 되는군요
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
12년 전 조회 3,413
12년 전 조회 5,065
12년 전 조회 4,374
12년 전 조회 2,829
12년 전 조회 9,066
12년 전 조회 3,826
12년 전 조회 4,072
12년 전 조회 3,166
12년 전 조회 4,844
12년 전 조회 2,727
12년 전 조회 2,482
12년 전 조회 3,112
12년 전 조회 2,678
12년 전 조회 3,347
12년 전 조회 2,648
12년 전 조회 3,122
12년 전 조회 3,209
12년 전 조회 2,565
12년 전 조회 2,845
12년 전 조회 6,526
12년 전 조회 2,918
12년 전 조회 2,226
12년 전 조회 2,591
12년 전 조회 3,732
12년 전 조회 2,371
12년 전 조회 2,650
12년 전 조회 3,057
12년 전 조회 2,475
12년 전 조회 1,771
12년 전 조회 2,954
12년 전 조회 2,583
12년 전 조회 8,923
12년 전 조회 3,465
12년 전 조회 3,248
12년 전 조회 3,315
12년 전 조회 3,865
12년 전 조회 1,948
12년 전 조회 5,051
12년 전 조회 2,694
12년 전 조회 7,796
12년 전 조회 2,329
12년 전 조회 2,339
12년 전 조회 2,386
12년 전 조회 2,004
12년 전 조회 4,244
12년 전 조회 2,772
12년 전 조회 2,806
12년 전 조회 2,345
12년 전 조회 3,996
12년 전 조회 3,013
12년 전 조회 1,767
12년 전 조회 4,857
12년 전 조회 2,354
12년 전 조회 2,122
12년 전 조회 2,524
12년 전 조회 6,861
12년 전 조회 2,494
12년 전 조회 4,084
12년 전 조회 3,559
12년 전 조회 1,794
12년 전 조회 4,236
12년 전 조회 2,703
12년 전 조회 2,625
12년 전 조회 2,671
12년 전 조회 4,586
12년 전 조회 3,381
12년 전 조회 4,999
12년 전 조회 9,865
12년 전 조회 5,475
12년 전 조회 5,071
12년 전 조회 2,645
12년 전 조회 2,736
12년 전 조회 4,470
12년 전 조회 5,303
12년 전 조회 5,703
12년 전 조회 2,910
12년 전 조회 2,620
12년 전 조회 2,255
12년 전 조회 2,276
12년 전 조회 4,050
12년 전 조회 4,038
12년 전 조회 2,597
12년 전 조회 4,132
12년 전 조회 2,590
12년 전 조회 9,707
12년 전 조회 2,888
12년 전 조회 5,084
12년 전 조회 7,699
12년 전 조회 2,880
12년 전 조회 4,194
12년 전 조회 1,909
12년 전 조회 2,576
12년 전 조회 2,446
12년 전 조회 2,624
12년 전 조회 4,623
12년 전 조회 2,416
12년 전 조회 3,136
12년 전 조회 2,559
12년 전 조회 2,233
12년 전 조회 2,680