Background Image

FORUM

Kim
조회 수 667 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

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

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

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


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

큐브리드 10에  Delphi(XE8) - UniDac - ODBC 연계하여 프로그램 사용중인데 아래 3가지 문의좀 드리겠습니다


ODBC 드라이버: CUBRID_ODBC-10.2-latest-unicode-win32-x64.zip


1. Window10에 ODBC 드라이버 설치하고 프로그램 실행하면 아래와 같이 오류가 발생합니다

   " DB연결 오류:  126: 지정된 모듈을 찾을 수 없습니다

      ...  cubrid_odbc32.dll) 시스템 오류가 발생하여 지정한 드라이버를 로드하지 못했습니다"


  - 제어판의 ODBC설정 화면에서 추가에서도 동일한 오류 발생

  - Window7 에서는 정상 작동합니다


2. 컬럼 갯수가 100개인 테이블에 Insert 시 오류발생

    테스트해본 결과 Insert 컬럼수가 66개까지는 정상나 66개를 넘어서면 오류발생합니다

    Insert는 host변수 사용하여 insert 합니다

    Insert into Tbl(c1, ..., c100) values(:C1, ..., :C100); 


3. 1,000건씩 Batch Insert시 오류발생합니다

   ODBC버전은  Batch Insert 지원이 안되는 건가요?


   




  • ?
    김병욱 2019.12.30 10:17
    안녕하세요,
    답변에 앞서 cubrid odbc 드라이버를 사용하신 환경에 대해 말씀해 주시면 문제 파악에 도움이 될 수 있습니다.
    - CUBRID DBMS 버전
    - 사용 중인 Windows OS 버전 및 환경 (32비트 / 64비트)
    - 적용했던 데이터베이스 테이블 스펙
    - 시험했던 프로그램 코드 샘플

    우선은 제가 시험했던 환경을 기준으로 질문하신 내용에 대해 아래와 같이 답변 드립니다.

    1. Window10에 ODBC 드라이버 설치하고 프로그램 실행하면 아래와 같이 오류가 발생합니다
    현재 사용 중인 OS가 Windows 10 64비트라면 32비트 odbc 드라이버를 사용할 수 없습니다.
    64비트 Windows 10에서는 64비트 odbc를 사용해야 합니다. 아래와 같은 Windows Path에서 odbcad32.exe 를 실행시켜서 세팅해야 합니다.

    %windir%\syswow64

    2. 컬럼 갯수가 100개인 테이블에 Insert 시 오류발생
    아래와 같이 테이블을 만들어서 시험을 해봤습니다.

    CREATE Table tbl_100 (c00 int, c01 int, ... c99 int);

    SQLINTEGER id = 100;
    SQLLEN cbid = 0;

    for (int i = 1; i <= 100; i++) {
    retcode = SQLBindParameter(hStmt, i, SQL_PARAM_INPUT, SQL_C_LONG,
    SQL_INTEGER, 0, 0, &id, 0, &cbid);
    }
    retcode = SQLExecDirect(hStmt, L"insert into tbl_100 values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, \
    ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) \
    ", SQL_NTS);

    위 코드를 통해 최종적으로 오류 없이 c00 ~ c99까지 100개의 칼럼 각각에 100이라는 값이 세팅되어 tbl_100에 생성되는 것을 확인했습니다.
    Table 구성을 어떻게 해서 시험해보셨는지 말씀해 주시면 동일한 환경에서 시험해 보도록 하겠습니다.

    3. 1,000건씩 Batch Insert시 오류발생합니다
    현재 cubrid odbc 드라이버에서는 BATCH 처리를 지원하지 않습니다.

    SQLINTEGER support;
    SQLSMALLINT cb;
    retcode = SQLGetInfo(dbc, SQL_BATCH_SUPPORT, &support, 100, &cb);

    위 코드를 실행해 보시면 support가 0으로 나옵니다. 즉, 현재는 Batch처리를 지원하지 않고 있습니다. 차기 odbc버전에서 batch 처리에 대해 검토할 예정입니다.
    그리고 1000개의 insert 쿼리를 어떻게 실행을 했는지, 샘플 코드를 말씀해주시면 좀더 상세한 답변을 드리도록 하겠습니다.
  • ?
    Kim 2020.01.06 17:22
    Win10 (64bit) 에서 응용프로그램을 32비트로 빌드해서 사용하면 오류가 나는데

    응용프로그램을 64bit로 빌드해서 사용하니 1번, 2번 모두 정상 처리됩니다

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 23
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4453
3991 "DATABASE 검사" 도무지 끝날 기미가 안 보입니다 5 한종희 2011.08.02 8583
3990 "DBMS, 0, Unknown DBMS error" 요건 무슨 애러인가요?;; 2 eitetu 2011.06.02 14296
3989 "Token length is too long" 오류에 관하여 질문 드립니다. 4 file 김우람 2009.01.09 21477
3988 & 등의 특수문자등이 변환되어 저장되는 경우 1 호랑이야옹 2012.12.28 10678
3987 ' 의 입력 방식이 궁금합니다. 1 이석희 2009.04.10 13422
3986 (1개의 댓글은 작성자가 썼습니다.)비주얼 베이직 큐브리드 연동후 동시에 여러 테이블 보는 방법문의 2 secret 강남우 2012.12.21 58
3985 (Re:) 회원가입이 3명이상 안돼요... 6 딩이 2010.07.08 7595
3984 (python)centOS7 docker 연결 문의입니다. 리얼비 2021.11.01 107
3983 (댓글 질문등록 했습니다.)이전글, 다음글 기능(LAG, LEAD) ORDER BY절 FOR ORDERBY_NUM() 추가해도 그대로 입니다 3 취우다 2017.04.19 5959
3982 (함수)펑션 오류 확인부탁드립니다. 1 초코초코초 2023.02.10 102
3981 *variable* 에러 1 hwon 2013.06.14 11619
3980 ++ cubrid server start: fail 2 file 토네이도 2013.09.13 13700
3979 -74 오류 조치 방법 1 덜쇠 2013.08.07 7643
3978 .AccessViolationException (C#) 1 swift 2021.06.03 219
3977 .NET 4.5 에서의 NHibernate 문제, .NET 4.0 에서 NHibernate + TransactionScope 활용 문제. 1 websiter 2017.06.09 2056
3976 .NET DB 제어를 위한 방법. 2 우페 2008.11.23 60878
3975 .net db목록 관련 질문 드립니다. 4 파인 2021.03.05 134
3974 // 를 사용하고 싶습니다. 1 죽통군 2010.02.10 9583
3973 /etc/hosts 파일 수정 1 secret chocob 2014.10.13 13
3972 /etc/rc3.d/S98cubrid 화일 좀 바꿔주세요 1 꽁꽁단무지 2017.01.25 12246
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

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