Background Image
질의작성
2017.08.04 00:18

테이블 명세서 쿼리

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

단축키

Prev이전 문서

Next다음 문서

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

 

SELECT

        c.class_name AS tbl_nm,

        a.attr_name AS attr_nm,

        CONCAT(

        CASE WHEN t.type_name = 'STRING'

                       THEN 'VARCHAR'

                       ELSE t.type_name

        END,

        CASE WHEN t.type_name = 'NUMERIC'

               THEN CONCAT('(', REPLACE(FORMAT(d.prec, 0), ',', ''), ', ', REPLACE(FORMAT(d.scale, 0), ',', ''), ')')

               WHEN t.type_name = 'ENUM'

               THEN ''--CAST(d.enumeration AS VARCHAR)

               /* ENUM 컬럼의 선언 부를 VARCHAR 로 변환 안됨 사후 처리 필요 */

               ELSE CONCAT('(', REPLACE(FORMAT(d.prec, 0), ',', ''), ')')

        END) AS attr_def,

        CASE    WHEN a.is_nullable = 1

                       THEN 'Y'

                       ELSE ''

        END AS attr_null,

        /* 9.x 하위 버전 */

        IF(a.data_type IN (4, 25, 26, 27, 35),

               SUBSTRING_INDEX((SELECT coll_name FROM _db_collation coll WHERE coll.coll_id = [d].[code_set]),'_',1),'') AS attr_char,

        IF(a.data_type IN (4, 25, 26, 27, 35),

               (SELECT coll_name FROM _db_collation coll WHERE coll.coll_id = [d].[code_set]),'') AS attr_coll,

        /* 10.x 전용 쿼리 */

--      IF(a.data_type IN (4, 25, 26, 27, 35),

--             (SELECT ch.charset_name FROM _db_charset ch WHERE d.code_set = ch.charset_id), '') AS attr_charset,

--      IF(a.data_type IN (4, 25, 26, 27, 35),

--             (SELECT coll.coll_name FROM _db_collation coll WHERE d.collation_id = coll.coll_id), '') AS attr_collation,

        a.default_value,

        /* 9.x 하위 버전 */

        (SELECT [description] FROM _cub_schema_comments cmt WHERE cmt.table_name = c.class_name AND cmt.column_name = a.attr_name) AS col_cmt,

        /* 10.x 전용 쿼리 */

--      a.comment,

        FORMAT(

        CASE WHEN t.type_name = 'SHORT' THEN 2.0

                       WHEN t.type_name = 'INTEGER' THEN 4.0

                       WHEN t.type_name = 'BIGINT' THEN 8.0

                       WHEN t.type_name = 'NUMERIC' THEN 16.0

                       WHEN t.type_name = 'FLOAT' THEN 4.0

                       WHEN t.type_name = 'DOUBLE' THEN 8.0

                       WHEN t.type_name = 'MONETARY' THEN 12.0

                       WHEN t.type_name IN ('CHAR', 'STRING', 'VARCHAR') THEN d.prec

                       WHEN t.type_name IN ('TIMESTAMP','TIMESTAMPLTZ') THEN 4.0

                       WHEN t.type_name = 'DATE' THEN 4.0

                       WHEN t.type_name = 'TIME' THEN 4.0

                       WHEN t.type_name IN ('DATETIME','DATETIMELTZ','TIMESTAMPTZ') THEN 8.0

                       WHEN t.type_name = 'DATETIMETZ' THEN 12.0

                       WHEN t.type_name = 'BIT' THEN FLOOR(d.prec / 8.0)

                       WHEN t.type_name = 'BIT VARYING' THEN FLOOR(d.prec / 8.0)

               ELSE 0

        END, 0) || ' Byte' AS attr_byte

FROM

        _db_class c,

        _db_attribute a,

        _db_domain d,

        _db_data_type t

WHERE

        a.class_of = c

        AND d.object_of = a

        AND d.data_type = t.type_id

        AND c.is_system_class = 0

        AND c.class_name = 'a'

ORDER BY

        c.class_name,

        a.def_order

  • ?
    덴드로비움 2017.09.09 15:49

    정말 잘 사용하고 있습니다.
    요기에 _db_index, db_index_key 를 포함시켜서 PK, FK 까지 YES,no 로 뽑을려고 하니 잘안되네요 ㅠㅠ
    방법이 없을까요?


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
24 기타 Oracle import 시 character set 변경관련 김창휘 2016.12.26 8609
23 기타 JBoss 사용 시 statement pooling 설정 손승일 2016.12.16 2903
22 기타 Tomcat's JDBC Pool 사용 시 JNDI DataSource 설정 손승일 2016.12.16 6436
21 기타 CUBRID HA에서 사용하는 포트 확인 방법(1523, 59901) 주현 2015.07.01 8153
20 기타 전자정부 표준프레임워크 CUBRID 사용 방법 문의 참조 cubebridge 2012.09.17 20588
19 기타 CUBRID csql -i 옵션 사용시 주의 사항 이용미 2011.12.22 9173
18 기타 테이블에 comment 사용하기 1 남재우 2010.01.01 21050
17 기타 glo 사용시 loaddb 주의 사항 웁쓰 2009.12.31 18650
16 기타 EVALUATE method 수행시 주의해야 할 점 웁쓰 2009.12.31 12875
15 기타 CUBRID 설치 서버의 OS bit 확인하는 방법과 CUBRID bit 확인 방법. file seongjoon 2009.12.15 18961
14 기타 좀비 프로세스 일괄 삭제하기 janus 2009.12.12 32049
13 기타 CUBRID의OLE DB 드라이버 설치 방법. file seongjoon 2009.08.24 16262
12 기타 CUBRID JDBC Driver 빌드 방법 웁쓰 2009.07.01 16941
11 기타 OS별 CPU, memory, kernel bit 를 확인하는 방법입니다. 남재우 2009.06.30 26902
10 기타 ODBC 드라이버만 따로 배포하는 방법 1 file 손승일 2009.06.26 18059
9 기타 조건절에 상수가 아닌 ? 가 있는 질의 플랜보는 방법 손승일 2009.05.28 17564
8 기타 windows vista 환경의 csql에서 ;edit 실행시 오류발생하는 경우 file 손승일 2009.05.27 16686
7 기타 csql에서 Java SP를 이용 조회 시 한글 깨짐현상 조치방법 cubebridge 2009.05.21 21043
6 기타 cubrid: error while loading shared libraries 에러가 발생했을 경우 대처 웁쓰 2009.05.19 22434
5 기타 windows에서의 Build 오류 발생 시 조치방법 cubebridge 2009.05.19 14254
Board Pagination Prev 1 2 Next
/ 2

Contact Cubrid

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