Background Image
조회 수 21256 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

큐브리드 9.1부터 추가 된 MERGE INTO 구문이 지원 된다.


프로그램 개발 시에 데이타 존재 유무에 따라 insert 또는 update를 수행한다.


즉, 

1. 저장하고자 하는 데이터 존재 여부를 select 문으로 조회

2. 조회한 결과 데이터가 존재하지 않으면 insert, 존재하면 update

 

위 처리내용을 Merge into 구문을 사용하여, 한개의 SQL문으로 처리 할 수 있다.


사용 예시는 아래와 같다.



1. 테스트 테이블 생성

CREATE TABLE test_tbl (

code CHAR(3) NOT NULL,

name varchar(40) NOT NULL,

continent varchar(10),

capital varchar(30),

CONSTRAINT pk_test_tbl PRIMARY KEY(code)

); 


2. Merge into 구문 실행 ( 테스트 테이블의 code컬럼에 'DAL'이 있는지 확인, 없음으로 insert문 실행 )

MERGE INTO test_tbl A USING  db_root  

ON   A.code = 'DAL'                 // 조건문

WHEN MATCHED THEN           // 조건문에 해당하는 데이터가 있을 때   UPDATE문 실행

         UPDATE    SET A.name = 'Dal Na La La', A.continent='Space Space', A.capital = ''


WHEN NOT MATCHED THEN   // 조건문에 해당하는 데이터가 없을 때  INSERT문 실행

          INSERT (A.code, A.name, A.continent, A.capital) VALUES ('DAL', 'Dal Na La', 'Space', ''  );

 


3. 데이타 확인 ( merge into 구문에서 insert문 실행 결과 )

SELECT * FROM test_tbl;


=== <Result of SELECT Command in Line 1> ===


  code                  name                  continent             capital

========================================================================================

  'DAL'                 'Dal Na La'         'Space'             '' 


4. Merge into 구문 실행 ( 테스트 테이블의 code컬럼에 'DAL'이 있는지 확인, 있음으로 update문 실행 )

MERGE INTO test_tbl A USING  db_root  

ON   A.code = 'DAL'                 // 조건문

WHEN MATCHED THEN           // 조건문에 해당하는 데이터가 있을 때   UPDATE문 실행

         UPDATE    SET A.name = 'Dal Na La La', A.continent='Space Space', A.capital = ''


WHEN NOT MATCHED THEN   // 조건문에 해당하는 데이터가 없을 때  INSERT문 실행

          INSERT (A.code, A.name, A.continent, A.capital) VALUES ('DAL', 'Dal Na La', 'Space', ''  );

 


5. 데이타 확인 ( merge into 구문에서 update문 실행 결과 )

SELECT * FROM test_tbl;


=== <Result of SELECT Command in Line 1> ===


  code                  name                  continent             capital

========================================================================================

  'DAL'                 'Dal Na La La'         'Space Space'             ''

 






  1. windows 환경에서 압축파일로 CUBRID 설치시 환경변수 쉽게 설정하기

    Date2015.07.02 Category운영관리 By김승훈 Views6995
    Read More
  2. CUBRID dummy data생성-간단편

    Date2015.07.01 Category질의작성 By주현 Views7858
    Read More
  3. CUBRID HA에서 사용하는 포트 확인 방법(1523, 59901)

    Date2015.07.01 Category기타 By주현 Views8165
    Read More
  4. 카디시안(한 Row를 여러 Row) 쿼리문 만들기

    Date2015.06.30 Category질의작성 By엄기호 Views10927
    Read More
  5. 32bit JRE 환경에서 64bit CUBRID Tool 사용

    Date2015.06.30 CategoryCUBRID 매니저 By손승일 Views7190
    Read More
  6. CUBRID Manager 및 엑셀 파일을 이용하여 데이터 입력 시, garbage값이 포함되어 저장되는 경우 해결 방법

    Date2015.06.17 CategoryCUBRID 매니저 By이용미 Views9754
    Read More
  7. SQL튜닝 - 인덱스 활용 사례

    Date2015.06.04 Category질의작성 By권호일 Views12014
    Read More
  8. JAVA SP 사용 시 로그 처리 방법

    Date2015.06.03 Category응용개발 By손승일 Views8574
    Read More
  9. 디비와 테이블 문자셋이 다른 경우 처리 방법

    Date2015.06.03 Category운영관리 By이용미 Views15802
    Read More
  10. A테이블의 다수의 컬럼을 B테이블로 UPDATE 하는 SQL

    Date2015.05.07 Category질의작성 By김승훈 Views7411
    Read More
  11. 전체 레코드 개수 확인하는 SP

    Date2015.05.07 Category응용개발 By김승훈 Views14728
    Read More
  12. MERGE INTO 사용 예제 ( INSERT, UPDATE문을 1개의 쿼리로 실행 )

    Date2015.05.01 Category질의작성 By권호일 Views21256
    Read More
  13. 워크스페이스 사용중입니다. 다른 워크스페이스를 선택하세요. 대응법

    Date2015.04.24 CategoryCUBRID 매니저 By성진 Views10507
    Read More
  14. CUBRID Manager 메모리 설정하기(cubridmanager.ini)

    Date2015.04.24 CategoryCUBRID 매니저 By성진 Views13707
    Read More
  15. CUBRID HA와 Primary key 제약조건

    Date2015.04.21 Category운영관리 By정만영 Views11347
    Read More
  16. 테이블 사용량 확인방법

    Date2015.02.03 Category운영관리 By정만영 Views11452
    Read More
  17. cubrid manager server 구동 시 no "events" section in configuration 오류 발생

    Date2014.07.03 CategoryCUBRID 매니저 By손승일 Views10262
    Read More
  18. 9.2 버전에서 복제 재구축(ha_make_slavedb.sh) 스크립트를 사용하려면 수정해야 할 부분

    Date2013.10.24 Category운영관리 Bybrightest Views12231
    Read More
  19. CUBRID vs MySQL vs ORACLE SQL 타입별 비교

    Date2013.07.12 Category마이그레이션 By정만영 Views69161
    Read More
  20. 오류데이타검증 - 숫자 이외의 데이타 확인하는 방법

    Date2013.01.17 Category질의작성 By권호일 Views21121
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales