Background Image

FORUM

조회 수 10022 추천 수 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 도구 출시 안내 admin 2024.04.23 128
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4476
1203 SQL 에러 질문 1 카르마 2010.10.16 9958
1202 큐브리드에도 테이블 정보를 담고 있는 DB가 있나요? 2 파란토끼 2013.09.27 9959
1201 리눅스 환경에서 자동실행.... 1 석균 2012.06.25 9963
1200 cubridmanager 의 호스트 목록이 가끔 사라집니다. 1 하야로비 2010.03.19 9975
1199 비쥬얼 스튜디오 2005에서 MFC로 프로그램을 개발 했을 때의 DB 연결 2 틈새 2013.03.06 9980
1198 해시분할 문의 2 초보 2010.04.10 9983
1197 C++ Embedded SQL에서 호스트 변수로 클래스 데이터 선언 가능 여부 문의 1 리겔 2012.04.20 9983
1196 디비 사용자 추가시 오류 문의드립니다. 1 큐브초보 2010.03.24 9984
1195 QTADO와 OLEDB사용시 문제 4 flypig 2010.01.29 9989
1194 data_buffer_page 를 300000 이상으로 늘렸더니 1 초보 2010.02.02 9996
1193 oracle_style_empty_string 의 설정 관련 group_concat 함수 사용 문제 1 혁이 2013.07.18 9996
1192 src.rpm에 있는 소스 중 1 아주가끔은 2009.10.16 10000
1191 visual-sql 설치 파일 2 무시2 2010.09.29 10001
1190 [초보질문] 쿼리편집기에 대한 질문입니다. 2 몰라몰라 2011.08.28 10002
1189 서브쿼리 관련 질문입니다. 7 눈꽃 2009.10.19 10004
1188 Cubird 9.1 버전 single_byte_compare 속성 1 하루야 2013.04.17 10006
1187 CUBRID Manager 에서 기본설정 -> 질의 편집기 옵션 -> UTF8로 변경방법 알려주세요! 3 혀니짱 2011.03.24 10011
1186 큐브리드 매니저 오류 2 마이나스 2010.10.08 10015
1185 리눅스상에서 백업파일의 Backup Time을 알수있는 방법이 있나요? 1 럭키늘보 2010.02.19 10018
1184 delete로 날리기 전 데이터 조회 방법좀 알려주세여 1 QA 2013.10.11 10018
Board Pagination Prev 1 ... 136 137 138 139 140 141 142 143 144 145 ... 201 Next
/ 201

Contact Cubrid

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