Background Image

FORUM

조회 수 1331 추천 수 0 댓글 4
?

단축키

Prev이전 문서

Next다음 문서

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


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, mybatis, jdbc


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


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

mybatis를 사용해서 bulk insert or update를 하나의 쿼리로 작성중에 있는데요
mysql 같은 경우 아래와 같이 values 키워드를 통해서 insert가 안되면 insert하고자 했던 내용으로 update가 가능하도록 할 수 있는 것으로 알고 있습니다.

<insert id="upsert" parameterType="map" useGeneratedKeys="false">
    INSERT
    INTO tt(
    a, b, c
    )
    VALUES
    <foreach collection="list" item="item" separator=",">
        (
        , #{item.a} as a
        , #{item.b} as b
        , #{item.c} as c
        )
    </foreach>
    ON DUPLICATE KEY UPDATE
    a = values(a),
    b = values(b)
</insert>

cubrid에서도 가능한 방법이 있을까요 ?

 

  • ?
    권호일 2021.07.14 13:14
    아래와 같이 변경해서 테스트 해 보세요.


    <insert id="upsert" parameterType="map" useGeneratedKeys="false">
    INSERT
    INTO tt(
    a, b, c
    )
    VALUES
    <foreach collection="list" item="item" separator=",">
    (
    #{item.a}
    , #{item.b}
    , #{item.c}
    )
    </foreach>
    ON DUPLICATE KEY UPDATE
    a = #{item.a},
    b = #{item.b}
    </insert>
  • ?
    dodev 2021.07.15 08:36
    일전에 테스트를 해보았었는데요, item을 파라미터로 인식하고 파라미터를 못찾는 바인딩 예외가 발생합니다.

    org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException
  • ?
    오명환 2021.07.15 09:49
    cubrid는 on duplicate key update 구문에 values() 를 지원하고 있지 않습니다.
    mybatis구문에서 foreach 구문에 on duplicate key update 구문까지 넣어서 변경해보세요.
    <foreach collection="list" item="item" separator=",">
    (
    , #{item.a} as a
    , #{item.b} as b
    , #{item.c} as c
    )
    ON DUPLICATE KEY UPDATE
    a = #{item.a} ,
    b = #[item.b]
    </foreach>

    그리고, cubrid 에서 replace into 구문을 지원합니다. 동작은 insert on duplicate key update와 동일하고, 사용은 insert 구문과 유사합니다.
    <insert id="upsert" parameterType="map" useGeneratedKeys="false">
    REPLACE
    INTO tt(
    a, b, c
    )
    VALUES
    <foreach collection="list" item="item" separator=",">
    (
    #{item.a}
    , #{item.b}
    , #{item.c}
    )
    </foreach>
    </insert>
  • ?
    dodev 2021.07.15 10:57
    테스트를 해보니 foreach 문 안쪽으로 ON DUPLICATION KEY UPDATE 문을 넣어서도 안되는 것 같네요. grammer 예외로 나오네요

    그리고 replace 같은 경우 update 조건이 되었을 때, 행을 제거하고 새로 삽입하기 때문에 ON DUPLICATE KEY UPDATE 문을 적극 이용해보려고 했던 상황이였는데요,
    아무래도 불가능하다면 REPLACE도 고려해봐야겠네요

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 71
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4466
3719 큐브리드에서 오프소스 Talend 사용 가능한 지 문의드립니다. 3 본부장 2021.05.24 185
3718 큐브리드에서 오라클로 연동할 수 있나요? 1 현쥬리 2009.11.02 10198
3717 큐브리드에서 멀티 데이터베이스를 지원하나요? 1 까망군 2009.11.21 9529
3716 큐브리드에서 덤프하는 방법 질문하겠습니다. 1 겸둥이k 2021.08.04 1244
3715 큐브리드에서 ddl 를 뽑아내고 싶습니다. 3 varsql 2020.05.18 797
3714 큐브리드에도 테이블 정보를 담고 있는 DB가 있나요? 2 파란토끼 2013.09.27 9959
3713 큐브리드에 제공하는 파티셔닝 사용후 조회시 문제 5 file 연습용 2021.09.01 169
3712 큐브리드에 있는 sql데이터를 다른사이트에 표출하는방법 3 꼴통개발자 2019.11.05 180
3711 큐브리드에 데이타 타입 지정문제 4 지니보이 2009.12.26 20203
3710 큐브리드에 db link 기능이 있나요? 1 김성일컴퍼니 2013.07.18 10413
3709 큐브리드에 Synonym기능 있나요? 1 김성일컴퍼니 2013.07.18 10890
3708 큐브리드에 PK, FK, INDEX 이름명 변경 신텍스 문의 드립니다. 1 덴드로비움 2017.08.30 1068
3707 큐브리드앱스팩 설치문의 1 오케이디바이스 2009.11.26 9069
3706 큐브리드설치에러;; 1 가루구 2009.02.14 12593
3705 큐브리드설정 문의 5 초보 2010.04.13 10026
3704 큐브리드상에서 한글을 깨지지 않고 자르는 방법이 있을까요? 1 file 안지민 2012.03.13 9326
3703 큐브리드메니저 브로커 접속 에러 - 353 1 leemited 2020.06.24 172
3702 큐브리드매니져로 테이블에 MULTISET 추가시 1 하나엘 2009.12.02 10126
3701 큐브리드매니저의 아이콘 개선 요청 3 file 고영진 2009.09.24 11361
3700 큐브리드매니저에서서버접속시연결오류가납니다 2 secret 훈이아빠 2016.12.01 15
Board Pagination Prev 1 ... 10 11 12 13 14 15 16 17 18 19 ... 200 Next
/ 200

Contact Cubrid

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