Background Image

FORUM

조회 수 13038 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

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

많은 도움이 되었습니다.

 

그런데 DBCP가 생성한 객체에서 OID나 Collection을 꺼내는 게 불편하지만 불가능한것은 아니라고 하신거 같은데요.

 

1. 정확한 절차나 예제를 올려 주실수 있나요?

 

 

 

네이버 개발자 센터에 올라온

 PreparedStatement pstmt = con.prepareStatement(sql);
  DelegatingStatement d_stmt = (DelegatingStatement) ((DelegatingStatement) pstmt).getDelegate();
  CUBRIDPreparedStatement cubrid_stmt = (CUBRIDPreparedStatement) d_stmt.getDelegate();

 

이걸 시도해 보니 마지막 줄에서 PoolablePreparedStatement를 CUBRIDPreparedStatement 로 캐스팅 못한다고 오류가 나네요.

 

 

 

그리고 그다지 추천하지 않는 방법이라고 하셨는데,

 

제가 생각하기에는 특정 WAS에 의존적이 된다는것과, 성능저하가 있을것 같다는것 같은데

 

2. 그 이외의 문제가 있나요?

 

가능하면 DBCP를 사용하고, OID나 Collection의 직접 입출력은 최소화시키는 방법으로 구현하려 합니다.

 

 

 

또, 혹시 차후버전에서 getOID, getCollection같은 확장된 메소드를

 

3. 처음부터 표준에 존재하는 getRowId, getArray 등이나, getObject로 지원하실 계획은 없는지 알고싶습니다.

 

 

  • ?
    cgkang 2011.03.31 23:39

    1.  두번째 문장까지 수행된 후에 d_stmt.toString() 값을 확인해보시기 바랍니다.

      toString()으로 반환되는 클래스 이름이 jdbc 드라이버에서 생성된 클래스 이름을 확인할 수 있을겁니다.

      그리고 반환된 object에 대해 d_stmt.getClass().getName()  과 같은 방법으로  해당 object의 클래스 이름을 확인할 수 있을겁니다.

      getDelegate() 함수를 여러번 호출해야 할 수 있으니 각 단계에서 실제 어떤 클래스인지를 확인해보기 바랍니다.

     

    2. SQL을 통해서만 사용한다면 특별히 문제될만한건 없습니다.

    collection을 사용할 경우 CUBRID는 다른 타입에 대한 collection (heterogeneous set) 을 지원하고 있지만,

    이런 경우는 모델링도 어렵지만, java의 array를 통해 전달할수 없어서 사용할 수 없습니다.

    예를 들어 set(int, string)과 같은 타입으로 컬럼을 생성할 수는 있지만, 데이터 입출력은 되지 않으니, 한가지 타입으로 사용하기 바랍니다.

     

    3. RowID, getArray등 지원은 아직 고려하고 있지 않습니다.

    그렇지만, oid나 collection모두 Object타입으로 받거나 보낼수 있으므로 크게 문제되지는 않을겁니다.

    collection타입의 경우, 예를 들어 set(string) 타입이라면 String[]로 캐스팅하여 값을 꺼내고, String[]를 setObject를 통해 전달할 수 있습니다.

    OID의 경우 CUBRIDOID 에서 확장된 메소드를 사용하면 OID를 String형태로 저장하는 것이 가능하고,

    저장된 값으로 CUBRIDOID 객체를 직접 만드는 것이 가능하지만, 이런 형태로 OID에 대한 세부적인 핸들링은 좋지 않습니다.

    select의 결과로 나온 object를 다른 테이블에 입력하는 등의 과정에서는 oid를 핸들링할수 밖에 없겠지만, 이 경우에는 Object 자체를 전달하는 정도로 사용하는 것이 좋습니다.

  • ?
    안지민 2011.04.01 07:16

    답변정말 감사합니다. 많은 도움이 되었습니다.


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 21 admin 2024.04.23 143856
1028 cci_connect 의 에러코드에 관하여 질문드립니다 7 엥꼬 2011.06.29 12716
1027 csql 로 demodb 접속 시 오류 입니다~! 1 하하보이 2011.06.29 15280
1026 R3.1 64비트 서브쿼리 관련 문의 드립니다 2 hj 2011.06.28 10896
1025 php 모듈 로드 문제 입니다. 2 하하보이 2011.06.28 11807
1024 Table primary key잡는 중 중단 시키고, 서버 재시작하니 에러나고 시작이 안되네요. 1 미스터투 2011.06.28 10390
1023 4.0 정식판은 언제쯤 나올까요? 2 유니콘 2011.06.28 10879
1022 Connect Error 1 제이씨씨 2011.06.24 19012
1021 ERROR(196623) 무슨에러인가요? 1 닉넴 2011.06.24 12036
1020 IIS 7.5 x64 / PHP 5.3 x64 / Cubrid R4.0 x64... 1 platanus 2011.06.23 14715
1019 큐브리드매니저에서 dba암호를 걸어버리면 연결할수 없다.브로커와 구동상태를 점검하라. 이렇게 오류가 나오네요 2 블루토토 2011.06.23 12916
1018 연결(Connection)을 얻을 수 없습니다. 브로커와 서버의 구동 상태를 점검하십시오. 이 에러가 납니다 3 블루토토 2011.06.22 16889
1017 PHP에서 CUBRID 4.0 모듈이 로드 되지 않습니다. 1 file 유리심장 2011.06.22 13983
1016 DB MS949를 UTF로 변환 하는 방법이 궁굼합니다. 1 dktk 2011.06.21 16571
1015 큐브리드매니저에서 질의결과가 나타나지 않습니다. 3 file 미스터투 2011.06.19 12306
1014 Code::Blocks - CCI 개발 환경 문의 3 reerror 2011.06.17 16083
1013 리눅스 민트(우분투)에서 cci 개발 환경 구축 방법 5 reerror 2011.06.16 18341
1012 외부에서 메니져 접속이 안됩니다. 3 platanus 2011.06.14 15505
1011 백업시 lgar 파일이 지워지지 않는 문제 6 동현 2011.06.11 23528
1010 ResulstSet이 닫혔는데... 닫히는 이유가 먼가요? 3 안지민 2011.06.10 18479
1009 ODBC, OLEDB 접속후, ADO 프로그래밍을 했을 때.. 1 lkim 2011.06.09 16537
Board Pagination Prev 1 ... 157 158 159 160 161 162 163 164 165 166 ... 213 Next
/ 213

Contact Cubrid

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