database.sarang.net
UserID
Passwd
Database
DBMS
MySQL
PostgreSQL
Firebird
Oracle
Informix
Sybase
ㆍMS-SQL
DB2
Cache
CUBRID
LDAP
ALTIBASE
Tibero
DB 문서들
스터디
Community
공지사항
자유게시판
구인|구직
DSN 갤러리
도움주신분들
Admin
운영게시판
최근게시물
MS-SQL Q&A 6709 게시물 읽기
No. 6709
다음 오라클 구문을 MS-SQL 로는 어떻게 변경하나여?
작성자
최종길(kiri123)
작성일
2013-08-13 15:44
조회수
7,701

UPDATE TABLEA A

SET (A.FIELDA,A.FIELDB) = (SELECT NVL(SUM(B.FIELDA),0),NVL(SUM(B.FIELDB),0)

FROM TABLEB B

WHERE B.FIELDC = @FIELDC

AND B.FIELDD = @FIELDD)

WHERE A.FIELDC = @FIELDC

AND A.FIELDD BETWEEN @FFIELDD AND @TFIELDD

AND EXISTS (SELECT C.FIELDD FROM TABLEB C

WHERE C.FIELDC = A.FIELDC

AND C.FIELDD = A.FIELDD);

 

 

위 오라클 구문을 MS-SQL 로 바꾸면 어떻게 하나여?

이 글에 대한 댓글이 총 1건 있습니다.
UPDATE TABLEA
SET FIELDA = B2.fa
, FIELDB = B2.fb
FROM TABLEA AS A
INNER JOIN ( 
SELECT @FIELDC AS fc
, ISNULL( SUM( FIELDA ), 0 ) AS fa
, ISNULL( SUM( FIELDB ), 0 ) AS fb
FROM TABLEB AS B
WHERE B.FIELDC = @FIELDC
AND B.FIELDD = @FIELDD
) AS B2
ON A.FIELDC = B2.fc
WHERE A.FIELDC = @FIELDC
AND A.FIELDD BETWEEN @FFIELDD AND @TFIELDD
AND EXISTS (
SELECT C.FIELDD 
FROM TABLEB C
WHERE C.FIELDC = A.FIELDC
AND C.FIELDD = A.FIELDD
)
;
우욱님이 2013-08-13 19:01에 작성한 댓글입니다. Edit
[Top]
No.
제목
작성자
작성일
조회
6712합계된 금액 조회하기 [1]
헬프미
2013-08-21
7922
6711mssql studio를 이용해서 db에서 db로 복사(백업)할 수 있나요? [1]
박두현
2013-08-20
7833
6710제가 구문을 잘못 썼네여 다시 한번 오라클 구문 조언 바랍니다 [2]
최종길
2013-08-14
7622
6709다음 오라클 구문을 MS-SQL 로는 어떻게 변경하나여? [1]
최종길
2013-08-13
7701
6708테이블의 레코드를 늘여서 보는 방법 없을까여? [2]
최종길
2013-08-12
7393
6707초데이터에서 분당 평균 구하기 [1]
윤창기
2013-08-08
8052
6706DB 복사 [2]
어서와
2013-08-08
7629
Valid XHTML 1.0!
All about the DATABASE... Copyleft 1999-2024 DSN, All rights reserved.
작업시간: 0.020초, 이곳 서비스는
	PostgreSQL v16.4로 자료를 관리합니다