메뉴 건너뛰기

조회 수 8145 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

중복 조인을 피하기 위한 update 방법에 대해 알아보겠습니다.

 
    UPDATE TotalPoint T
          SET usePoint = (SELECT usePoint
                                     FROM UserPoint U WHERE U.userId = T.userId),
              totPoint = totPoint + (SELECT usePoint
                                                FROM UserPoint U WHERE U.userId = T.userId)
        FROM userId = 'testUser'

이런식으로 서브쿼리를 2번 같은 내용으로 사용하는 것은 비효율적이다.
만약에 더 많은 컬럼값을 Update해야 한다면 중복이 더 많아질 것이다.

Merge를 사용하면 이러한 중복을 줄일 수 있다.

 

    MERGE INTO TotalPoint T
     USING (
                     SELECT userId,
                               usePoint
                        FROM UserPoint U
                      WHERE userId = 'testUser'
               ) U
         ON (T.userId = U.userId)
     WHEN MATCHED THEN
     UPDATE SET T.totPoint = T.totPoint + U.usePoint,
                T.userPoint = U.usePoint

 

이렇게 Merge를 사용하면 중복조인의 문제를 피할 수 있어 좋다.

오라클에서, '중복조인 방지를 위한 UPDATE'에 대한 더 자세한 글은 다음 링크에서 확인할 수 있다.
http://scidb.tistory.com/111


List of Articles
번호 제목 날짜 조회 수
81 오라클(PL/SQL) 미리 정의된 예외처리 2016.12.08 7215
80 오라클 계정 lock 해제 2016.12.08 8444
79 ORA-01652 128(으)로 테이블 공간 ***에서 임시 세그먼트를 확장할 수 없습니다. file 2016.12.08 9257
78 IMP-00010: 엑스포트 파일이 유효하지 않고, 헤더가 검증에 실패했습니다 file 2016.12.08 8814
77 오라클 DB 생성 후 설정 Listener.ora & Tnsnames.ora (윈도우) file 2016.12.08 23312
76 오라클11g DB 생성 file 2016.12.08 9727
75 오라클 테이블 생성 스크립트 DDL 추출 - 깔끔하게 Table 전부 추출(Export)하기 file 2016.12.08 12549
74 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 12409
73 Oracle DBMS_CRYPTO 사용하기 - 암복호화 하기 file 2016.12.08 11642
72 sqlplus에서 Ampersand나 특수 문자를 갖는 데이타를 insert하는 방법 sqlplus 데이터 insert 입력값 요구 2016.12.08 8914
71 Oracle SQL Developer 도구 활용하기 - Part2 file 2016.12.08 11317
70 Oracle SQL Developer 도구 활용하기 - Part1 file 2016.12.08 11743
69 ORA-39142 덤프 버전이 틀려서 넣지 못할 때 2016.12.08 8981
68 데이터의 암호화 및 복호화 file 2016.12.08 13248
67 oracle 에서 Index를 이용해서 즉 힌트와 rownum을 이용하여 게시판 작성하기 2016.12.08 7023
66 오라클에서 레코드 값이 없을때 2016.12.08 13470
65 CLOB TEXT 데이타를 저장하고, 조회하는 예제 2016.12.08 13083
64 오라클 25가지 SQL 작성법 2016.12.08 7710
63 rownum 사용 - 최근글 몇개만 가져오기 2016.12.08 9989
62 Oracle Batch Processing 2016.12.08 6829
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved