Background Image

FORUM

조회 수 7177 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Linux 64x
CUBRID Ver.
CUBRID 9.3.6.0002
CUBRID TOOL Ver.
CUBRID Manager 9.3.6.007
응용 환경(API)
java, jdbc

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

-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
Java 저장프로시저를 활용하여 CURSOR을 사용하려고 합니다.
Java에서 CURSOR을 호출 하였으나 NullPointerException 이 발생하여 문의드립니다.

public static ResultSet getPhone()
    {
        String qry = "SELECT * FROM PHONE";
        try
        {
            Connection conn = CubridConn.cubrid_conn();

            PreparedStatement stmt = conn.prepareStatement(qry, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
            ResultSet rs = stmt.executeQuery();
            ((CUBRIDResultSet)rs).setReturnable();
            rs.last();
            int cnt = rs.getRow();
            System.out.println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!RS CNT : " + cnt);

            return rs;
        }
        catch( Exception ex )
        {
            ex.printStackTrace();
        }
        return null;
    }

위 부분이 CURSOR의 JAVA부분입니다.

CREATE FUNCTION getPhone() RETURN CURSOR AS LANGUAGE JAVA
NAME 'PhoneNumber.getPhone() RETURN java.sql.ResultSet';

위 부분으로 Function(CURSOR) 생성 하였습니다.

public static void printPhone()
    {
        Connection conn = null;

        try
        {
            conn = CubridConn.cubrid_conn();
            CallableStatement stmt = conn.prepareCall("?=CALL getPhone()");
            stmt.registerOutParameter(1, Types.JAVA_OBJECT);
            stmt.execute();
            ResultSet rs = (ResultSet)stmt.getObject(1);

            if( rs == null )
            {
                System.out.println("!!!!!!!!!!!!RS IS NULL");
                rs.close();
                return;
            }
            rs.close();
        }
        catch( Exception ex )
        {
            ex.printStackTrace();
        }
    }

위 부분이 CURSOR을 호출 하는 부분이고

CREATE PROCEDURE printPhone() AS LANGUAGE JAVA
NAME 'PhoneNumber.printPhone()';

위 부분으로 프로시저를 작성하여 CUBRID Manager를 통해 프로시저를 호출하였습니다.

CURSOR 부분에 불러온 갯수를 찍도록 표시하였고 결과가 정상적으로 출력이 되었지만

printPhone에서는 계속 null 이라고 나오는데 확인 부탁드립니다.
  • ?
    이상신 2017.03.22 21:38

    안녕하세요 ~


     우선 getPhone() 

     ((CUBRIDResultSet)rs).setReturnable(); --> Error Multiple markers at this line - CUBRIDResultSet cannot be resolved to a type

    발생하여 주석 처리 후 TEST 진행 하였으며 결과 RS CNT 찍는것 까지 확인 하였습니다.


    null 발생원인은 SP 호출시 호출한 쿼리의 Connection을 계속 같이 사용하기에 

    아래 소스와 같이 기존 커넥션 null 처리 함으로서 발생한다 판단됩니다.

    public static void printPhone()
        {
            Connection conn = null;

    더 궁금한점이 있는 경우 해당 소스 전체을 보내 주십시오

    감사합니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 120
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4476
3860 트리거 생성시 문법 질문 1 초콜릿75 2013.07.03 13431
3859 트리거 삭제 오류 1 file slqk135 2024.01.08 91
3858 트리거 사용시 임시변수 1 지구인다 2018.10.01 253
3857 트리거 등록 후 정보 확인시 오류사항 2 file 종이 2014.08.11 8531
3856 트리거 동작 문의 1 종이 2016.08.12 14126
3855 트리거 inactive 오류 1 단순미학 2010.07.01 8051
3854 트리거 delete on 문법 문의 1 aliveJune 2009.10.05 10742
3853 트리거 delete after시 상관명을 써야합니다. 1 루피 2013.11.07 19636
3852 트리거 ACTIVE/INACTIVE 설정 2 할리 2014.06.18 7842
3851 트랜젝션 처리에 대해 1 kkndo2 2015.04.13 8337
3850 트랜잭션처리 시간지연에 대한 문의입니다. 2 file 히로키 2009.12.03 12337
3849 트랜잭션이(인덱스 1, dba@localhost|20383) 시스템에 의해 취소되었습니다. 1 스마트 2011.01.06 8012
3848 트랜잭션의 상세정보를 확인할수 있는 방법이 있나요? 1 김현성 2011.06.01 10566
3847 트랜잭션과 커밋에 관한 질문 2 유니콘 2011.03.03 10228
3846 트랜잭션 오류 문의 1 oneh 2018.07.18 380
3845 트랜잭션 교착상태 1 초보 2010.04.14 11936
3844 트랜잭션 관련하여 질문드립니다. 6 봉보로봉봉 2017.08.02 415
3843 트랜잭션 관련 추가 문의입니다. 5 메이커스 2009.07.31 9152
3842 트랜잭션 관련 문의입니다. 4 메이커스 2009.07.25 9313
3841 트랜잭션 격리 수준 관련한 에러 메시지 6 file gjgj 2021.07.15 156
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 200 Next
/ 200

Contact Cubrid

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