테이블,컬럼 comments (정보관리테이블만들기)
< 정보테이블 생성하기 >
---------------------------------------------------------------------
DROP TABLE TB_INFO;
CREATE TABLE TB_INFO (
OWNER VARCHAR(15) NOT NULL,
TABLE_NAME VARCHAR(30) NOT NULL,
TABLE_COMMENTS VARCHAR(200) ,
COLUMN_NAME VARCHAR(30) NOT NULL,
COLUMN_COMMENTS VARCHAR(200) ,
COLUMN_ID NUMBER,
DATA_TYPE VARCHAR(20) NOT NULL,
NULLABLE CHAR(1) NOT NULL,
TABLE_TYPE VARCHAR(20)
)
TABLESPACE TS_COM_TB
;
COMMENT ON COLUMN TB_INFO.OWNER IS 'OWNER';
COMMENT ON COLUMN TB_INFO.TABLE_NAME IS '테이블명';
COMMENT ON COLUMN TB_INFO.TABLE_COMMENTS IS '테이블설명';
COMMENT ON COLUMN TB_INFO.COLUMN_NAME IS '컬럼명';
COMMENT ON COLUMN TB_INFO.COLUMN_COMMENTS IS '컬럼설명';
COMMENT ON COLUMN TB_INFO.COLUMN_ID IS '컬럼ID';
COMMENT ON COLUMN TB_INFO.DATA_TYPE IS '데이터타입';
COMMENT ON COLUMN TB_INFO.NULLABLE IS 'NULL허용여부';
COMMENT ON COLUMN TB_INFO.TABLE_TYPE IS '테이블형태';
ALTER TABLE TB_INFO
ADD ( CONSTRAINT PK_INFO PRIMARY KEY (OWNER, TABLE_NAME,COLUMN_NAME)
USING INDEX
TABLESPACE TS_COM_IX ) ;
GRANT INSERT, UPDATE, DELETE ON TB_INFO TO ROLE_COM_W;
GRANT SELECT ON TB_INFO TO ROLE_COM_R;
CREATE PUBLIC SYNONYM TB_INFO FOR COM.TB_INFO;
commit;
---------------------------------------------------------------------
< 실제 테이블에 테이블정보 넣기 >
---------------------------------------------------------------------
DELETE
FROM TB_INFO
WHERE OWNER =
(select distinct(user) from user_tables);
INSERT INTO TB_INFO
select TB_COM.OWNER,
TB_COM.TABLE_NAME,
TB_COM.TCOMMENTS,
TB_COM.COLUMN_NAME,
TB_COM.CCOMMENTS,
TB_COL.COLUMN_ID,
TB_COL.DATA_TYPE,
TB_COL.NULLABLE,
TB_COM.TABLE_TYPE
FROM
(select user as OWNER,
a.TABLE_NAME as TABLE_NAME,
a.COMMENTS as TCOMMENTS,
b.COLUMN_NAME as COLUMN_NAME,
b.COMMENTS as CCOMMENTS,
a.TABLE_TYPE as TABLE_TYPE
from user_tab_comments a, user_col_comments b
where
a.table_name = b.table_name(+)
and a.comments is not null) TB_COM,
(select table_name, column_name, nullable, column_id,
(CASE WHEN data_precision is null THEN data_type||'('||data_length||')'
WHEN data_scale = 0 THEN data_type||'('||data_length||')'
ELSE data_type||'('||data_precision||'.'||data_scale||')'
END) as data_type
from user_tab_columns) TB_COL
WHERE TB_COM.TABLE_NAME = TB_COL.TABLE_NAME
and TB_COM.COLUMN_NAME = TB_COL.COLUMN_NAME;
commit;
---------------------------------------------------------------------
위 내용으로 작성되어진 예시 캡쳐화면을 첨부합니다.
위 예제는 테이블명,테이블스페이스명,롤,시너님을 수정하셔서
실제 프로젝트에서 사용하는 쿼리이기에 환경만 만드시거나 조정만 하시면 충분히 사용하실듯 하네요.
^^ 오랫만에 접속해보는군요. 다시 자주 찾아 뵙도록 하겠습니다.
edit512 골뱅이 네이트 닷컴
---------------------------------------------------------------------
DROP TABLE TB_INFO;
CREATE TABLE TB_INFO (
OWNER VARCHAR(15) NOT NULL,
TABLE_NAME VARCHAR(30) NOT NULL,
TABLE_COMMENTS VARCHAR(200) ,
COLUMN_NAME VARCHAR(30) NOT NULL,
COLUMN_COMMENTS VARCHAR(200) ,
COLUMN_ID NUMBER,
DATA_TYPE VARCHAR(20) NOT NULL,
NULLABLE CHAR(1) NOT NULL,
TABLE_TYPE VARCHAR(20)
)
TABLESPACE TS_COM_TB
;
COMMENT ON COLUMN TB_INFO.OWNER IS 'OWNER';
COMMENT ON COLUMN TB_INFO.TABLE_NAME IS '테이블명';
COMMENT ON COLUMN TB_INFO.TABLE_COMMENTS IS '테이블설명';
COMMENT ON COLUMN TB_INFO.COLUMN_NAME IS '컬럼명';
COMMENT ON COLUMN TB_INFO.COLUMN_COMMENTS IS '컬럼설명';
COMMENT ON COLUMN TB_INFO.COLUMN_ID IS '컬럼ID';
COMMENT ON COLUMN TB_INFO.DATA_TYPE IS '데이터타입';
COMMENT ON COLUMN TB_INFO.NULLABLE IS 'NULL허용여부';
COMMENT ON COLUMN TB_INFO.TABLE_TYPE IS '테이블형태';
ALTER TABLE TB_INFO
ADD ( CONSTRAINT PK_INFO PRIMARY KEY (OWNER, TABLE_NAME,COLUMN_NAME)
USING INDEX
TABLESPACE TS_COM_IX ) ;
GRANT INSERT, UPDATE, DELETE ON TB_INFO TO ROLE_COM_W;
GRANT SELECT ON TB_INFO TO ROLE_COM_R;
CREATE PUBLIC SYNONYM TB_INFO FOR COM.TB_INFO;
commit;
---------------------------------------------------------------------
< 실제 테이블에 테이블정보 넣기 >
---------------------------------------------------------------------
DELETE
FROM TB_INFO
WHERE OWNER =
(select distinct(user) from user_tables);
INSERT INTO TB_INFO
select TB_COM.OWNER,
TB_COM.TABLE_NAME,
TB_COM.TCOMMENTS,
TB_COM.COLUMN_NAME,
TB_COM.CCOMMENTS,
TB_COL.COLUMN_ID,
TB_COL.DATA_TYPE,
TB_COL.NULLABLE,
TB_COM.TABLE_TYPE
FROM
(select user as OWNER,
a.TABLE_NAME as TABLE_NAME,
a.COMMENTS as TCOMMENTS,
b.COLUMN_NAME as COLUMN_NAME,
b.COMMENTS as CCOMMENTS,
a.TABLE_TYPE as TABLE_TYPE
from user_tab_comments a, user_col_comments b
where
a.table_name = b.table_name(+)
and a.comments is not null) TB_COM,
(select table_name, column_name, nullable, column_id,
(CASE WHEN data_precision is null THEN data_type||'('||data_length||')'
WHEN data_scale = 0 THEN data_type||'('||data_length||')'
ELSE data_type||'('||data_precision||'.'||data_scale||')'
END) as data_type
from user_tab_columns) TB_COL
WHERE TB_COM.TABLE_NAME = TB_COL.TABLE_NAME
and TB_COM.COLUMN_NAME = TB_COL.COLUMN_NAME;
commit;
---------------------------------------------------------------------
위 내용으로 작성되어진 예시 캡쳐화면을 첨부합니다.
위 예제는 테이블명,테이블스페이스명,롤,시너님을 수정하셔서
실제 프로젝트에서 사용하는 쿼리이기에 환경만 만드시거나 조정만 하시면 충분히 사용하실듯 하네요.
^^ 오랫만에 접속해보는군요. 다시 자주 찾아 뵙도록 하겠습니다.
edit512 골뱅이 네이트 닷컴
[이 게시물은 관리자님에 의해 2011-10-31 16:47:36 Oracle에서 이동 됨]
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 130 | 20년 전 | 3961 | ||
| 129 | 20년 전 | 2902 | ||
| 128 | 20년 전 | 3627 | ||
| 127 | 20년 전 | 3425 | ||
| 126 | 20년 전 | 3718 | ||
| 125 | 20년 전 | 8557 | ||
| 124 | 20년 전 | 2581 | ||
| 123 | 20년 전 | 3732 | ||
| 122 | 20년 전 | 3185 | ||
| 121 | 20년 전 | 2582 | ||
| 120 | 20년 전 | 2648 | ||
| 119 | 20년 전 | 2560 | ||
| 118 | 20년 전 | 2848 | ||
| 117 |
|
20년 전 | 3026 | |
| 116 | 20년 전 | 5286 | ||
| 115 | 20년 전 | 3889 | ||
| 114 | 20년 전 | 4935 | ||
| 113 | 20년 전 | 6193 | ||
| 112 | 20년 전 | 7315 | ||
| 111 | 20년 전 | 18417 | ||
| 110 | 20년 전 | 6866 | ||
| 109 | 20년 전 | 2863 | ||
| 108 | 20년 전 | 4116 | ||
| 107 |
prosper
|
20년 전 | 2466 | |
| 106 |
prosper
|
20년 전 | 4289 | |
| 105 |
아우겐나이스
|
20년 전 | 2881 | |
| 104 | 20년 전 | 2241 | ||
| 103 | 20년 전 | 2457 | ||
| 102 | 20년 전 | 2208 | ||
| 101 | 20년 전 | 2541 | ||
| 100 | 20년 전 | 1720 | ||
| 99 | 20년 전 | 1552 | ||
| 98 | 20년 전 | 1602 | ||
| 97 | 20년 전 | 2095 | ||
| 96 | 20년 전 | 1855 | ||
| 95 | 20년 전 | 2354 | ||
| 94 | 20년 전 | 3548 | ||
| 93 | 20년 전 | 1541 | ||
| 92 | 20년 전 | 1734 | ||
| 91 | 20년 전 | 3153 | ||
| 90 | 20년 전 | 2327 | ||
| 89 | 20년 전 | 3152 | ||
| 88 | 20년 전 | 2856 | ||
| 87 | 20년 전 | 3284 | ||
| 86 | 20년 전 | 5099 | ||
| 85 | 20년 전 | 2503 | ||
| 84 | 20년 전 | 4802 | ||
| 83 | 20년 전 | 2478 | ||
| 82 | 20년 전 | 3091 | ||
| 81 | 20년 전 | 7597 | ||
| 80 | 20년 전 | 3801 | ||
| 79 | 20년 전 | 3192 | ||
| 78 | 20년 전 | 4678 | ||
| 77 | 20년 전 | 2880 | ||
| 76 | 20년 전 | 6203 | ||
| 75 | 20년 전 | 4461 | ||
| 74 | 20년 전 | 5764 | ||
| 73 | 20년 전 | 3614 | ||
| 72 | 20년 전 | 5950 | ||
| 71 | 20년 전 | 3092 | ||
| 70 | 20년 전 | 2818 | ||
| 69 | 20년 전 | 2611 | ||
| 68 | 20년 전 | 2425 | ||
| 67 | 20년 전 | 2632 | ||
| 66 | 20년 전 | 2654 | ||
| 65 | 20년 전 | 3775 | ||
| 64 | 20년 전 | 2801 | ||
| 63 | 20년 전 | 2440 | ||
| 62 | 20년 전 | 2243 | ||
| 61 | 20년 전 | 3044 | ||
| 60 | 20년 전 | 3113 | ||
| 59 | 20년 전 | 2488 | ||
| 58 | 20년 전 | 2576 | ||
| 57 | 20년 전 | 2946 | ||
| 56 | 20년 전 | 2297 | ||
| 55 | 20년 전 | 2734 | ||
| 54 | 20년 전 | 2105 | ||
| 53 | 20년 전 | 2328 | ||
| 52 | 20년 전 | 2677 | ||
| 51 |
prosper
|
20년 전 | 2329 | |
| 50 |
prosper
|
20년 전 | 2148 | |
| 49 | 20년 전 | 2155 | ||
| 48 | 20년 전 | 2308 | ||
| 47 | 20년 전 | 1911 | ||
| 46 | 20년 전 | 1913 | ||
| 45 | 20년 전 | 2119 | ||
| 44 | 20년 전 | 2346 | ||
| 43 | 21년 전 | 4558 | ||
| 42 |
prosper
|
21년 전 | 2693 | |
| 41 |
prosper
|
21년 전 | 2094 | |
| 40 | 21년 전 | 2158 | ||
| 39 | 21년 전 | 2127 | ||
| 38 | 21년 전 | 2397 | ||
| 37 | 21년 전 | 2548 | ||
| 36 | 21년 전 | 1760 | ||
| 35 | 21년 전 | 4058 | ||
| 34 | 21년 전 | 3838 | ||
| 33 | 21년 전 | 2975 | ||
| 32 |
prosper
|
21년 전 | 2880 | |
| 31 | 21년 전 | 5248 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기