Background Image

FORUM


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Window7 64bit
CUBRID Ver.
9.2.9
CUBRID TOOL Ver.
사용하지 않음
응용 환경(API)
java(1.6) / jdbc (JDBC-9.2.9.0002-cubrid.jar)


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


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

안녕하세요 큐브리드JDBC를 사용중에

궁금한 것이 있어서 질문드립니다.

jdbc (JDBC-9.2.9.0002-cubrid.jar)를 이용해서

접속가능한 유저리스트 혹은 전체 유져리스트를 가져오기 위해

DatabaseMetaData클래스의 getSchemas를 사용했습니다만

ResultSet의 건수가 없습니다.

 

1. 접속가능한 유저리스트 혹은 전체 유져리스트를 가져오는 getSchemas를 잘못 활용한것이면 활용방법을 알려주세요

2. 접속가능한 유저리스트 혹은 전체 유져리스트를 가져오는 쿼리가 있다면 그것도 알려주세요

(Mysql예: SELECT SCHEMA_NAME AS TABLE_SCHEM FROM INFORMATION_SCHEMA.SCHEMATA)

 

그럼 답변 기다리겠습니다.

좋은하루 되세요~

 

소스

        String strUrl = "jdbc:cubrid:1.1.1.209:30000:demodb:::";
        String strUser = "demo_data";
        String strPasswd = "demo";
        Connection conn = null;
        ResultSet rs = null;
        PreparedStatement pstmt = null;
        try {
            Class.forName("cubrid.jdbc.driver.CUBRIDDriver");
            conn = DriverManager.getConnection(strUrl,strUser,strPasswd);
            DatabaseMetaData dbmd= conn.getMetaData();
            rs = dbmd.getSchemas();
            ResultSetMetaData rsmeta = rs.getMetaData();
            int colCnt = rsmeta.getColumnCount();
            System.out.print("-------------getSchemas-------------\n");
            for(int i=1; i<=colCnt; i++){
                String colName = rsmeta.getColumnLabel(i).toUpperCase();
                System.out.print("|"+colName+"|\t");
            }                 
            System.out.print("\n-------------------------------------\n");
            while(rs.next())
            {
                for (int i = 1; i <= colCnt; i++)
                {
                    String value = rs.getString(i);
                    System.out.print("["+value+"]\t");
                }
                System.out.println();
            }
        }catch(Exception e){    
            e.printStackTrace();
        }finally{
            if(rs!=null){ try{rs.close();}catch(Exception ex){} }
            if(pstmt!=null){ try{pstmt.close();}catch(Exception ex){} }
            if(conn != null){ try{conn.close();} catch(Exception ex){}}
        }

결과

-------------getSchemas-------------
|TABLE_SCHEM|    
-------------------------------------
 

 

TAG •
  • ?
    오명환 2017.09.01 16:34
    현재 JDBC에서는 getSchema() 함수가 구현되어 있지 않아, 직접 catalog에 질의를 수행해서 결과를 받아 처리하셔서 할 것 같습니다.
    getSchema() 함수는 향후 버젼에 반영할 예정입니다.
  • ?
    dator 2017.09.01 16:47
    아 그러면 "직접 catalog에 질의를 수행해서 결과를 받아 처리" 라고 하신부분을 어떻게 하면 되는지
    알수 있을까요?
  • ?
    오명환 2017.09.01 16:52
    catalog table 중에 db_user table를 참조하시면 됩니다. 자세한 column의 내용은 매뉴얼( http://www.cubrid.org/manual/ko/9.3.0/sql/catalog.html)을 참고하시면 됩니다.
    catalog table을 접근하기 위해서는 반드시 dba user 접근하셔야 합니다.

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