Background Image
질의작성
2017.08.04 00:18

테이블 명세서 쿼리

조회 수 3173 추천 수 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
번호 분류 제목 글쓴이 날짜 조회 수
139 CUBRID 매니저 UTF8 로 저장된 데이터를 매니저로 조회하는 방법 file Prototype 2009.03.21 25636
138 질의작성 UPDATE에서 조인을 통해, 결과값 수정하는 방법 박동윤 2016.12.27 7174
137 기타 Tomcat's JDBC Pool 사용 시 JNDI DataSource 설정 손승일 2016.12.16 6496
136 운영관리 TIME_TO_KILL과 SESSION_TIMEOUT에 대한 정리 cubebridge 2009.05.27 13191
135 질의작성 SQL튜닝 - 인덱스 활용 사례 권호일 2015.06.04 12014
134 운영관리 SElinux 환경에서 CUBRID 사용하기 2 admin 2008.11.21 25505
133 응용개발 PHP에서 prepared statement 사용하기 3 Prototype 2009.04.16 21454
132 응용개발 PHP에서 prepared statement 사용시 BIND 관련 팁 Prototype 2009.06.30 14843
131 응용개발 PHP에서 Prepared statement 사용시 NULL 값을 바인딩 하는 방법 1 Prototype 2009.11.27 19722
130 응용개발 PHP에 CUBRID 모듈 추가시 모듈이 로드되지 않는 문제에 대한 해결 방안 하나입니다 남재우 2010.07.01 16557
129 응용개발 PHP 프로그램을 작성할때 주의할 점 Prototype 2009.07.01 13728
128 응용개발 PHP 성능 최적화를 위한 고려 사항 웁쓰 2009.07.01 17415
127 응용개발 PHP PEAR extension 을 이용한 DB Time 추적 웁쓰 2009.07.01 19182
126 응용개발 PHP PEAR extension Cache-Lite 를 이용한 응용 프로그램 최적화 file 웁쓰 2009.07.01 17044
125 기타 Oracle import 시 character set 변경관련 김창휘 2016.12.26 8680
124 질의작성 Oracle UTL_ENCODE.TEXT_ENCODE를 CUBRID로 변환하기 김창휘 2016.03.21 4646
123 기타 OS별 CPU, memory, kernel bit 를 확인하는 방법입니다. 남재우 2009.06.30 26902
122 질의작성 ORACLE 테이블 및 컬럼 COMMENT 일광등록 스크립트 1 김창휘 2016.04.04 9335
121 질의작성 ORACLE TRIGGER를 CUBRID TRIGGER로 변환하기 김창휘 2015.12.31 6460
120 기타 ODBC 드라이버만 따로 배포하는 방법 1 file 손승일 2009.06.26 18060
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 14 Next
/ 14

Contact Cubrid

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