Background Image

FORUM

2023.04.24 13:00

Fk값 가져오기

조회 수 155 추천 수 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 api를 사용하여 테이블 fk를 뽑아내려 합니다. getImportedKeys로 받아서 처리하려고 하는데 어떻게 해야 되나요? 예제 소스에는 Test.printFkInfo(rs)로 되어있습니다



  • ?

    안녕하세요.

     

    11.2 버전 전과 후로 차이가 있습니다.

     

    11.2 버전부터는 사용자를 스키마 개념으로 사용하기 때문에 테이블명에 소유자 이름을 스키마 이름으로 지정해주셔야 합니다.
    접속하는 사용자가 테이블의 소유자인 경우에는 테이블명만 넣어주실 수 있습니다.

     

    소유자가 u1 사용자인 t1_pk과 t1_fk 테이블이 있을 때
    11.2 이전 버전과 이후 버전에서 getImportedKeys 함수를 실행하는 방법을 참고해주세요.

     

    u1 사용자를 생성하고, u1 사용자로 접속해서  t1_pk과 t1_fk 테이블을 생성합니다.

    csql -u dba demodb
    csql> create user u1;
    
    csql -u u1 demodb
    csql> create table t1_pk (c1 int primary key); /* owner: u1 */
    csql> create table t2_fk (c1 int primary key, c2 int references t1_pk); /* owner: u1 */

     

    11.2 이전 버전에서는 어떤 사용자로 접속했는지에 관계 없이 테이블명만 넣어주실 수 있었습니다.

    Connection connection = DriverManager.getConnection("jdbc:cubrid:192.168.xxx.xxx:33000:demodb:::", "dba", "");
    ResultSet resultSet = databaseMetaData.getImportedKeys(null, null, "t2_fk");

     

    11.2 이후 버전에서는 어떤 사용자로 접속했는지에 따라서 테이블명에 소유자 이름을 스키마 이름으로 지정해주셔야 합니다.

    /* dba 사용자로 접속하여 u1.t2_fk 테이블 확인. */
    Connection connection = DriverManager.getConnection("jdbc:cubrid:192.168.xxx.xxx:33000:demodb:::", "dba", "");
    ResultSet resultSet = databaseMetaData.getImportedKeys(null, null, "u1.t2_fk");
    
    /* u1 사용자로 접속하여 t2_fk 테이블 확인. */
    Connection connection = DriverManager.getConnection("jdbc:cubrid:192.168.xxx.xxx:33000:demodb:::", "u1", "");
    ResultSet resultSet = databaseMetaData.getImportedKeys(null, null, "t2_fk");

     

    감사합니다.

  • ?
    오명환 2023.04.24 15:19
    매뉴얼 예제에서 사용한 printFKInfo() 코드입니다. 참고하세요.

    public static void printFkInfo(ResultSet rs)
    throws Exception {
    while(rs.next()) {
    System.out.println("<" + rs.getString("FK_NAME") + ">");
    System.out.println("01. PKTABLE_CAT : " + rs.getString("PKTABLE_CAT"));
    System.out.println("02. PKTABLE_SCHEM : " + rs.getString("PKTABLE_SCHEM"));
    System.out.println("03. PKTABLE_NAME : " + rs.getString("PKTABLE_NAME"));
    System.out.println("04. PKCOLUMN_NAME : " + rs.getString("PKCOLUMN_NAME"));
    System.out.println("05. FKTABLE_CAT : " + rs.getString("FKTABLE_CAT"));
    System.out.println("06. FKTABLE_SCHEM : " + rs.getString("FKTABLE_SCHEM"));
    System.out.println("07. FKTABLE_NAME : " + rs.getString("FKTABLE_NAME"));
    System.out.println("08. FKCOLUMN_NAME : " + rs.getString("FKCOLUMN_NAME"));
    System.out.println("09. KEY_SEQ : " + rs.getString("KEY_SEQ"));
    System.out.println("10. UPDATE_RULE : " + CubridSUS434.getRuleName(rs.getString("UPDATE_RULE")));
    System.out.println("11. DELETE_RULE : " + CubridSUS434.getRuleName(rs.getString("DELETE_RULE")));
    System.out.println("12. FK_NAME : " + rs.getString("FK_NAME"));
    System.out.println("13. PK_NAME : " + rs.getString("PK_NAME"));
    System.out.println("14. DEFERRABILITY : " + CubridSUS434.getDeferrabilityName(rs.getString("DEFERRABILITY")));
    }
    }

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4149
» Fk값 가져오기 2 file 네오랜덤 2023.04.24 155
3843 서버 메모리 교체 및 ha 상 데이터 삭제 절차 1 레피엘 2023.04.20 99
3842 java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의 3 개미가불쌍해 2023.04.18 132
3841 Cubrid stored procedure 스케쥴 등록 형식 2 Roy 2023.04.17 103
3840 암호화 함수 MDB_ENC 질문입니다 1 BE-DEV 2023.04.17 76
3839 auto_increment 추가 방법 문의 1 부패방지운영팀 2023.04.14 200
3838 CUBRID 사용자 계정 생성 관련 문의 1 몽키스패너 2023.04.14 124
3837 order by 이후 rownum이 의도와 다르게 찍힙니다. 2 바보똥개 2023.04.14 129
3836 백업 및 복구 시 cubrid 버전 간 호환 문의 1 플레이어블 2023.04.13 70
3835 centos8에서 쉘스크립트 실행시 csql: command not found 오류 발생 6 kjn4345 2023.04.13 159
3834 큐브리드 timestamp 오류 문의 5 jjun7204 2023.04.12 138
3833 Cubrid DB 서버 swap memory 사용률 관련 질의 1 오라클민 2023.04.12 193
3832 Mac OS 큐브리드 매니저 실행이 안 됩니다. 2 아데산야라이트훅 2023.04.07 126
3831 blob select 1 네오랜덤 2023.04.05 119
3830 dba권한 상속 1 네오랜덤 2023.04.05 79
3829 mac os m1 실행시 무응답 실행안됩니다. 6 시나몬빵 2023.04.04 136
3828 함수/프로시져 구동시 필요한 java버젼 1 네오랜덤 2023.03.31 99
3827 큐브리드 설치 도중 취소한 후, 재설치가 불가능합니다. 5 복괴 2023.03.28 143
3826 where in () 서브쿼리 관련 문의입니다 1 제리리 2023.03.27 104
3825 한글을 입력받아 한글을 리턴하는 CUBRID JAVA StoredProcedure 작성시 window 환경에서 리턴 값이 깨져서 출력 됨 2 두목원슝 2023.03.22 155
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