JDBC를 활용해서 현재 접근권한이 부여된 유저리스트 혹은 전체 유져리스트를 얻는것이 가능한가요

by dator posted Sep 01, 2017


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

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 •