Background Image

FORUM

조회 수 1981 추천 수 0 댓글 3
?

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
  Linux 64bit
CUBRID Ver.
 9..x
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------

01/04 14:34:54 ERROR [NONE] folder data insert failed.
org.springframework.dao.DuplicateKeyException:
### Error updating database.  Cause: cubrid.jdbc.driver.CUBRIDException: Operation would have caused one or more unique constraint violations.


쿼리 구문으로  merge를 사용합니다.

: MERGE INTO tablename A USING DB_ROOT ON    (     A.serviceDomain = ?     AND A.folder = ?     AND A.timeMills = ?    )


상황은 4대의 백엔드 서버에서 데이터를 입력하는데 타이밍에 따라서 거의 동시에 일어 날수도 있습니다.

5분에 한번씩 데이터를 입력는데 하루 중 10번 정도는 중복오류가 발생하여 데이터가 입력되지 않습니다.


MERGE  구문에서 중복키 오류가 발생가능한지?

MERGE 대시 UPDATE 구문을 사용해야 하는건가요?


  • ?
    김창휘 2018.01.19 16:07
    안녕하세요. 중복시 update할 수 있습니다. 아래의 URL를 참고 바랍니다.
    WHEN MATCHED THEN UPDATE 구문 참조
    https://www.cubrid.org/manual/ko/9.3.0/sql/query/merge.html
  • ?
    블루미 2018.01.19 16:47
    전체 구문은 아래와 같고요..
    MERGE INTO xxxx_xxxx_folder_xxxx A USING DB_ROOT ON ( A.serviceDomain = ? AND A.folder = ? AND A.timeMills = ? ) WHEN MATCHED THEN UPDATE SET A.messageOutBytes = A.messageOutBytes + ?, A.plus = A.plus + 1, A.createDate = ? WHEN NOT MATCHED THEN INSERT ( A.serviceDomain, .folder, A.timeMills, A.messageOutBytes, A.plus, A.createDate )VALUES ( ?, ?, ?, ?, 1, ? )

    키 중복시 업데이트를 탈텐데.. 중복키 오류가 나서요. 하루 288건 중 대략 10건 정도 발생하네요.
  • ?
    김창휘 2018.01.19 17:13
    통상적으로 중복 발생시 해당 값으로 update하는 경우입니다만, 아래의 구문에서는 +1를 하고, 해당 테이블에 대해서 다른 session 또는 다른 응용에서 입력하는 경우 중복이 발생할 수도 있을 것 같아 보입니다.

  1. CUBRID 사용자를 위한 DBeaver 도구 출시 안내

    Date2024.04.23 Byadmin Views118
    read more
  2. SQLGate for CUBRID 영구 무료 라이선스 제공

    Date2020.04.09 Byadmin Views4474
    read more
  3. MS-SQL > ORDER BY NEWID() 있는데 큐브리드는 어떻게 적용되는지

    Date2017.09.08 By펌피 Views727
    Read More
  4. MS-Access ODBC 연결테이블

    Date2014.01.16 By무말랭이 Views12396
    Read More
  5. MODIFY CONSTRAINT 가능한가요?

    Date2013.10.28 Byagkim Views12034
    Read More
  6. MERGE INTO문 관련.

    Date2018.03.13 By고늬 Views1112
    Read More
  7. MERGE INTO 속도 개선 문의

    Date2023.06.12 Byleeee Views129
    Read More
  8. MERGE 쿼리 실행시 중복 입력 오류

    Date2018.01.19 By블루미 Views1981
    Read More
  9. MAX_PREPARED_STMT_COUNT Error 문의

    Date2020.01.14 By파랑조아유 Views572
    Read More
  10. Log 문의

    Date2021.06.25 Byjungsin Views113
    Read More
  11. Locale 확인방법 문의

    Date2020.07.20 Bybchlim Views262
    Read More
  12. Loaddb 유틸리티 사용시 log archive(lgar) 관련 문의

    Date2024.05.03 By뚜벅뚜벅 Views29
    Read More
  13. Linux에 설치된 Cubrid 매니저 접속 속도 문제

    Date2018.04.10 Bymcwony Views474
    Read More
  14. Linux상의 export한 cubrid dump파일 문의

    Date2012.11.30 By검풍전기 Views9
    Read More
  15. Linux 설치 전 확인 사항에 glibc 버전관련 입니다.

    Date2014.06.18 By어려운큐브 Views11879
    Read More
  16. Linux Centso5.1에 설치 중입니다.

    Date2010.01.27 ByPhilip Park Views8985
    Read More
  17. Linked server

    Date2009.02.20 By벅지 Views15582
    Read More
  18. Linked Server 조회시 한글깨짐

    Date2016.06.23 By라면파 Views15
    Read More
  19. Like 문이 의도하지 않은 결과값을 반환합니다.

    Date2010.02.25 By이진혁 Views12533
    Read More
  20. LOWER 오류가 왜 날까요?

    Date2010.01.15 By초보 Views10392
    Read More
  21. LOG 설정 관련 질문입니다.

    Date2023.02.23 Byjemin Views90
    Read More
  22. LINQ 지원 문의

    Date2009.11.10 ByAaron Views10704
    Read More
Board Pagination Prev 1 ... 156 157 158 159 160 161 162 163 164 165 ... 200 Next
/ 200

Contact Cubrid

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