Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 32bit & Linux 64bit
CUBRID Ver.
9.2.3
CUBRID TOOL Ver.
응용 환경(API)
C++


Lock 및 트랜젝션 처리에 대해 문의 드립니다.

자료를 이리저리 찾아보니,,큐브리드 관련 자료가 큐브리드에서 관리하는 사이트를 제외하고는 자료가 많지 않아,,,문의드립니다.

 

현재, 회사제품을 Mysql -> 큐브리드 로의 변환작업을 진행중입니다. (버전: 9.2.3)

개발교육자료에서 MVC가 미지원되어, Lock 및 트랙젝션 관리가 중요하다는 내용을 보았습니다.

 

[회사제품의 운영구성]

1. 여러개의 프로세스(ps)가 동시에 띄워져서,  하나의 DB에 있는 테이블들을 바라보며  insert, select, delete, update가 빈번히 이루어짐.

2. 단, 각 프로세스가 접근하는 레코드가 겹치지는 않으나, 동일한 테이블들임.

 

<질문1>

위의 구성으로 볼 때 , insert/delete/update 수행시, Lock 및 트랜젝션 관리가 필요합니까?

 

<질문2>

관리가 필요하다면,,,, 구현시 commit은 구체적으로 어떻게 처리해야 하나요?

  예를 들어,,

  설정파일으로 auto commit을 설정해서, insert/delete/update를 수행하면 되는 것인지,,,

   auto commit을 해제하고, 구현시 insert/update/delete 수행마다  수동으로 commit 해줘야 하는 건인지,,,

 

<질문3>

관리가 필요하다면,,,, 구현시 Lock은 구체적으로 어떻게 처리해야 하나요?

  예를 들어,,

   insert/delete/update 수행 전후에 테이블 Lock과 unLock을 수행해야 하나요?

 

<질문4>

자료를 찾아보니 아래와 같은 글귀가 있었습니다. (http://helloworld.naver.com/helloworld/89910)

--------------------------------------------------------------------------------------------------------------------------------------

MySQL은 fetch 도중 커밋이 발생해도 커서를 유지하지만 CUBRID는 fetch 도중 커밋이 발생하면 커서를 닫는다. 따라서 현재의 CUBRID 2008 R4.x 이하 버전에서 SELECT한 레코드셋을 fetch하는 도중 커서를 유지하도록 하려면 자동 커밋 모드를 false로 설정하고 트랜잭션을 커밋하지 않은 상태에서 fetch해야 한다. (하반기에 출시될 CUBRID의 새 버전에서는 레코드셋을 닫기 전까지는 커밋 여부에 관계없이 커서를 유지하도록 변경할 예정이다.)

--------------------------------------------------------------------------------------------------------------------------------------

현재, 9.2.3 버전을 사용하는데 있어서는 어떻게 개선되었는지 알아야지 구현시 반영할 수 있을 것 같습니다.

현재는 어떻지 알려주시면 감사하겠습니다.

 

 

 

 


  • ?
    이용미 2014.03.06 00:16
    안녕하세요. 아래와 같이 답변을 작성하였습니다.

    * 질문 1 : 말씀하신 것과 같은 구성으로는 응용에서의 트랜잭션 처리가 필요할 것으로 보입니다. 
          참고로, CUBRID에서는 auto_commit을 이용한 트랜잭션 처리가 가능하지만, 테이블에 Lock/Unlock을 명시하여 관리할 수는 없습니다. 그러나 말씀하신 것과 같이 여러 프로세스가 하나의 테이블에 접근하여 DML을 수행하는 경우, 테이블 Lock/Unlock은 필요하지 않을 것으로 보입니다.

    * 질문 2 : CUBRID에서는 C++ 관련 API 사용시, auto_commit은 Default로 ON으로 설정되어 있습니다. 그렇기 때문에 트랜잭션 처리를 위해서는 auto_commit을 OFF로 설정해 주신 후($CUBRID/conf/cubrid_broker.conf에서 트랜잭션 처리를 참고하여 설정) commit을 명시해 주셔야 합니다.
     
    * 질문 3 : 질문 1에서 답변드렸습니다.

    * 질문 4 : 말씀하신 부분은 정상적으로 반영되었습니다. 매뉴얼 [트랜잭션과 잠금 - 커서유지] 부분을 참고하여주세요.

    감사합니다.
  • ?
    모냐모냐 2014.03.07 23:18

    한 번 더 문의드릴께요.

    저희가 본의아니게 버전을 9.2.3에서 8.4.3으로 낮추어야 하는 상황이 되었네요.

    8.4.3 버전에서는 위의 질문에 대한 답변이 모두 기존과 동일한가요?

    한 번 더 답변 부탁드립니다.


  • ?
    이용미 2014.03.07 23:34

    답변 1~3까지는 동일합니다. 

    그러나 질문 4변의 경우는 CUBRID2008 R4.3 버전에 적용되지 않았으니 참고해주세요.


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 49
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
734 큐브리드 4.1 업그레이드 관련 질문 드립니다. 1 conomia 2012.11.02 5905
733 큐브리드 6.6에서 큐브리드 2008로 복구하는 방법좀.. 1 썬해바라기 2009.12.14 9506
732 큐브리드 64bit 설치 후 실행 문제. 1 초보개발꾼 2014.01.16 12043
731 큐브리드 64bit 설치 후 실행 문제.(2) 1 file 초보개발꾼 2014.01.21 14394
730 큐브리드 64비트 에서 32비트로 DB이전이 안됩니다. 도와주세요!~ 2 린설 2011.06.07 13098
729 큐브리드 7.3 ubloaddb시 object 파일 깨짐 현상 1 file 짜요짜요 2014.07.31 6875
728 큐브리드 8버전 시스템 카탈로그 테이블,컬럼 정보 문의 1 sonoru 2020.11.17 102
727 큐브리드 9.1 설치 후 에러 3 file Ryon 2013.04.01 6821
726 큐브리드 9.3 버전 Result Set Caching 설정 관련 질문 4 imwondol 2021.04.12 290
725 큐브리드 9.3 버전에서 9.2 버전 다운그레이드 방법좀... 1 나라보자 2015.09.22 6111
724 큐브리드 9.3 버전에서 dba 암호 분실시 어떻게 해야 하나요? 1 하늘나무 2018.07.04 551
723 큐브리드 9.3) 터미널을 이용하여 큐브리드 DB ubloaddb시 object 파일 깨짐 현상 3 file 솨솨솨 2021.03.18 297
722 큐브리드 9.3.6 버전에서 TRIM 이 안되는지요. 5 펌피 2017.10.25 669
721 큐브리드 C api 연동 방법/? 1 댄디 2013.02.18 5990
720 큐브리드 CCI API 사용함에 있어서 연결 유지 및 연결 검증에 대한 방법이 있나요? 1 정크 2020.03.31 108
719 큐브리드 CI 및 로고 파일을 얻고 싶습니다. 3 andante 2012.11.23 7620
718 큐브리드 CLOB , BLOB 은 최대 용량은 얼마인가요? 1 덴드로비움 2017.06.28 5312
717 큐브리드 DAMO(암호화)관련 버전 호환관련하여 문의드립니다. 3 초코초코초 2023.03.20 230
716 큐브리드 DB 복구 관련 문의 1 red03410 2014.03.18 6888
715 큐브리드 DB 복원 관련 문의 1 fewkgpokp 2023.08.14 76
Board Pagination Prev 1 ... 159 160 161 162 163 164 165 166 167 168 ... 200 Next
/ 200

Contact Cubrid

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