Background Image

FORUM

2023.04.24 13:00

Fk값 가져오기

조회 수 166 추천 수 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
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
734 컬럼의 dafualt 설정에 함수 쓰면 안되나요? 1 덴드로비움 2017.08.30 171
733 LIKE 조건 시 무한 조회 중.... 락이 걸리는거 같습니다... 1 처키친구 2021.02.10 171
732 큐브리드 데이터 타입 문의드립니다. 1 피닉스맨 2019.10.14 170
731 linux에서 php pdo driver 설치시 문의 개발자nn 2020.02.27 170
730 큐브리드 방화벽 관련해서 질문있습니다. 2 사블 2022.11.08 170
729 뷰 내보내기 시 ddl 짤림 1 코딩쟁이 2021.12.03 170
728 SQLGate Developer 업데이트 후 오류 1 문태환 2021.11.15 169
727 큐브리드에 제공하는 파티셔닝 사용후 조회시 문제 5 file 연습용 2021.09.01 169
726 cubrid 파라미터 바인딩 3 DJ 2023.03.14 168
725 큐브리드 서비스 멈춘 뒤 DB 덮어씌기 후 서비스 재시작이 안되는 경우 1 민수킴 2019.07.08 167
724 시스템 뷰 조회 성능 문의 4 bchlim 2020.12.22 167
723 SQLGate 데이터 내보내기 오류 1 써늬니 2022.10.25 167
722 HA 이중화 구성 시에 master, slave 관련하여 질문 드립니다. 1 k1n9 2022.11.02 167
721 CUBRID Manager 영문버전 제공여부 2 bikehee 2017.11.14 166
720 에러 로그 첨부 합니다. 5 file Philip Park 2020.10.15 166
719 loaddb 실행시 에러 해결방법 요청 2 이삭 2020.06.18 166
» Fk값 가져오기 2 file 네오랜덤 2023.04.24 166
717 특정단어 삭제 6 ddmmdd 2023.07.13 165
716 Cubrid 데이터베이스 생성 시 오류 확인 요청 3 file 딤디딤 2021.05.14 165
715 연계과정에서 질문드릴게있습니다. 1 qswaert 2017.11.16 165
Board Pagination Prev 1 ... 159 160 161 162 163 164 165 166 167 168 ... 200 Next
/ 200

Contact Cubrid

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