Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

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

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

안녕하세요.


jdbc통해 프로시저 작업도중


Attempted to operate a query result structure already closed. 이러한 에러가 나면서 종료가 되고 이후에 작업들이 다 멈추는 현상이 나타납니다.


해결 방법에 대해 답변좀 부탁드려요.



  • ?
    권호일 2019.02.25 13:54
    작성해 주신 내용만으로는 원인 파악이 어렵습니다.

    예상으로는 ResultSet 이 close 되어 있어서 next 또는 getString 등을 사용 할 수 없다는 오류로 보여집니다.

    프로시저 원본소스를 올려주면 원인파악에 도움이 될 것 같습니다.
  • ?
    큐브리드_김주현 2019.02.25 13:59
    큐브리를 이용해 주셔서 감사합니다.

    아래 내용 참고해보세요

    ++++++++++++++++++++++++++
    Attempt to access a closed ResultSet(PreparedStatement) 과 같은 오류는 일반적으로
    1. 질의의 사용 후 결과를 가져와 사용 중 commit/rollback을 수행 후 결과를 계속 가져오려 하는 경우 transaction이 종료되어 결과 셑이 닫혀버린 경우
    2. 구조상 한 클라이언트에서 서버로의 질의 수행 후 특정시간(SESSION TIME OUT)동안 서버로의 요청이 없어 서버단의 미들웨어(Broker)에서 연결을 강제 종료 시킨 경우
    위 2가지의 경우 발생할 수 있습니다.

    1의 경우는 주로 한 개의 ResultSet이 close()되기 전에 다른 ResultSet을 생성할 경우 앞의 ResultSet은 autoCommit되어 결과 셑이 닫혀버리면서 발생하는 데 이와 같이 동시에 여러 개의 ResultSet이 필요한 경우엔 autoCommit을 false로 설정해야 합니다.
    예를 들면
    try {
    conn.setAutoCommit(false);
    query1 = "SELECT id FROM sample1";
    pstmt1 = conn.prepareStatement(query1);
    query2 = "SELECT result FROM sample2 WHERE id=?";
    pstmt2 = conn.prepareStatement(query2);

    rs1 = pstmt1.executeQuery();
    while(rs1.next()){
    psmt2.setString(1, rs1.getString("id"));
    rs2 = pstmt2.executeQuery();
    result = rs2.getString("result");
    }
    conn.commit();

    } catch ( Exception e ) {
    conn.rollback();
    } finally {
    if ( conn != null ) conn.close();
    }

    와 같이 상단에서 autoCommit을 false로 설정하고 마지막에 commit()처리를 해주셔야 합니다. 물론 exception이 발생하면 rollback()처리도 해주셔야 합니다.

    2의 경우에는 큐브리드 브로커의 환경설정 중 SESSION_TIMEOUT 설정 값을 크게 늘려주는 방법으로 해결할 수 있습니다.

  1. SQLGate for CUBRID 영구 무료 라이선스 제공

  2. 브로커(CAS)수 질문드립니다!

  3. 데이터 이관 문의입니다.

  4. No Image 24May
    by 네오랜덤
    2023/05/24 by 네오랜덤
    Views 177 

    8.4.4 charset. Collation 확인 방법

  5. 8.4.4버젼 charset 확인

  6. 쿼리 속도 차이 질문

  7. spring boot 에서 HikariPool-1 - Driver does not support get/set network timeout for connections. (java.lang.UnsupportedOperationException) 질문 드립니다.

  8. cci 프로그래밍에서 DB LINK 관련 문의

  9. 큐브리드 매니저 실행이 오류

  10. ddl 추출

  11. 하나의 쿼리에서 복수 테이블 업데이트 방법 문의

  12. cubrid driver 설치 문의

  13. 큐브리드 매니저 접속 이 안됩니다. 확인 요청 드립니다.

  14. Fk값 가져오기

  15. 서버 메모리 교체 및 ha 상 데이터 삭제 절차

  16. java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의

  17. Cubrid stored procedure 스케쥴 등록 형식

  18. 암호화 함수 MDB_ENC 질문입니다

  19. No Image 14Apr
    by 부패방지운영팀
    2023/04/14 by 부패방지운영팀
    Views 242  Replies 1

    auto_increment 추가 방법 문의

  20. CUBRID 사용자 계정 생성 관련 문의

  21. order by 이후 rownum이 의도와 다르게 찍힙니다.

Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 ... 199 Next
/ 199

Contact Cubrid

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