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년 전 조회 2,078
12년 전 조회 3,780
12년 전 조회 3,099
12년 전 조회 1,548
12년 전 조회 7,784
12년 전 조회 2,546
12년 전 조회 2,802
12년 전 조회 1,874
12년 전 조회 3,555
12년 전 조회 1,452
12년 전 조회 1,195
12년 전 조회 1,846
12년 전 조회 1,423
12년 전 조회 2,073
12년 전 조회 1,390
12년 전 조회 1,826
12년 전 조회 1,905
12년 전 조회 1,335
12년 전 조회 1,563
12년 전 조회 5,261
12년 전 조회 1,637
12년 전 조회 964
12년 전 조회 1,338
12년 전 조회 2,451
12년 전 조회 1,108
12년 전 조회 1,429
12년 전 조회 1,803
12년 전 조회 1,229
12년 전 조회 504
12년 전 조회 1,701
12년 전 조회 1,329
12년 전 조회 7,619
12년 전 조회 2,204
12년 전 조회 1,972
12년 전 조회 2,034
12년 전 조회 2,481
12년 전 조회 578
12년 전 조회 3,707
12년 전 조회 1,370
12년 전 조회 6,413
12년 전 조회 1,009
12년 전 조회 977
12년 전 조회 1,275
12년 전 조회 667
12년 전 조회 3,112
12년 전 조회 1,421
12년 전 조회 1,486
12년 전 조회 987
12년 전 조회 2,618
12년 전 조회 1,656
12년 전 조회 445
12년 전 조회 3,508
12년 전 조회 1,012
12년 전 조회 826
12년 전 조회 1,205
12년 전 조회 5,560
12년 전 조회 1,193
12년 전 조회 2,809
12년 전 조회 2,258
12년 전 조회 481
12년 전 조회 2,945
12년 전 조회 1,386
12년 전 조회 1,293
12년 전 조회 1,354
12년 전 조회 3,274
12년 전 조회 2,042
12년 전 조회 3,703
12년 전 조회 8,587
12년 전 조회 4,180
12년 전 조회 3,750
12년 전 조회 1,365
12년 전 조회 1,437
12년 전 조회 3,152
12년 전 조회 3,992
12년 전 조회 4,396
12년 전 조회 1,610
12년 전 조회 1,301
12년 전 조회 886
12년 전 조회 987
12년 전 조회 2,725
12년 전 조회 2,736
12년 전 조회 1,257
12년 전 조회 2,804
12년 전 조회 1,282
12년 전 조회 8,464
12년 전 조회 1,519
12년 전 조회 3,776
12년 전 조회 6,386
12년 전 조회 1,571
12년 전 조회 2,839
12년 전 조회 592
12년 전 조회 1,300
12년 전 조회 1,161
12년 전 조회 1,318
12년 전 조회 3,312
12년 전 조회 1,088
12년 전 조회 1,823
12년 전 조회 1,260
12년 전 조회 913
12년 전 조회 1,402
🐛 버그신고