테이블,컬럼 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에서 이동 됨]
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 1230 |
|
18년 전 | 1993 | |
| 1229 |
|
18년 전 | 2921 | |
| 1228 |
|
18년 전 | 2613 | |
| 1227 | 18년 전 | 2914 | ||
| 1226 | 18년 전 | 2352 | ||
| 1225 |
|
18년 전 | 2422 | |
| 1224 | 18년 전 | 2731 | ||
| 1223 |
|
18년 전 | 3969 | |
| 1222 |
mixdesign
|
18년 전 | 2621 | |
| 1221 |
|
18년 전 | 2734 | |
| 1220 | 18년 전 | 3201 | ||
| 1219 | 18년 전 | 2905 | ||
| 1218 | 18년 전 | 2088 | ||
| 1217 |
|
18년 전 | 2537 | |
| 1216 | 18년 전 | 2540 | ||
| 1215 |
mixdesign
|
18년 전 | 4028 | |
| 1214 |
|
18년 전 | 4777 | |
| 1213 | 18년 전 | 2308 | ||
| 1212 |
mixdesign
|
18년 전 | 2479 | |
| 1211 |
|
18년 전 | 2413 | |
| 1210 | 18년 전 | 3751 | ||
| 1209 |
mixdesign
|
18년 전 | 2369 | |
| 1208 |
mixdesign
|
18년 전 | 2371 | |
| 1207 |
mixdesign
|
18년 전 | 1711 | |
| 1206 |
mixdesign
|
18년 전 | 1993 | |
| 1205 |
mixdesign
|
18년 전 | 2696 | |
| 1204 |
mixdesign
|
18년 전 | 3575 | |
| 1203 | 18년 전 | 3083 | ||
| 1202 | 18년 전 | 2966 | ||
| 1201 | 18년 전 | 2025 | ||
| 1200 | 18년 전 | 4120 | ||
| 1199 | 18년 전 | 2157 | ||
| 1198 | 18년 전 | 4191 | ||
| 1197 | 18년 전 | 2498 | ||
| 1196 | 18년 전 | 2342 | ||
| 1195 |
|
18년 전 | 3456 | |
| 1194 | 18년 전 | 2228 | ||
| 1193 | 18년 전 | 2139 | ||
| 1192 | 18년 전 | 3270 | ||
| 1191 | 18년 전 | 3946 | ||
| 1190 | 18년 전 | 2194 | ||
| 1189 |
|
18년 전 | 2342 | |
| 1188 |
|
18년 전 | 3822 | |
| 1187 | 18년 전 | 2703 | ||
| 1186 | 18년 전 | 3337 | ||
| 1185 | 18년 전 | 2761 | ||
| 1184 | 18년 전 | 1657 | ||
| 1183 | 18년 전 | 2118 | ||
| 1182 | 18년 전 | 3688 | ||
| 1181 |
mermaid
|
18년 전 | 2909 | |
| 1180 | 18년 전 | 2963 | ||
| 1179 | 18년 전 | 3600 | ||
| 1178 | 18년 전 | 2159 | ||
| 1177 |
|
18년 전 | 2270 | |
| 1176 | 18년 전 | 3164 | ||
| 1175 | 18년 전 | 1849 | ||
| 1174 |
|
18년 전 | 2218 | |
| 1173 |
|
18년 전 | 2522 | |
| 1172 | 18년 전 | 1763 | ||
| 1171 | 18년 전 | 2099 | ||
| 1170 | 18년 전 | 1986 | ||
| 1169 | 18년 전 | 2501 | ||
| 1168 | 18년 전 | 1919 | ||
| 1167 | 18년 전 | 1713 | ||
| 1166 | 18년 전 | 1742 | ||
| 1165 | 18년 전 | 1723 | ||
| 1164 | 18년 전 | 2760 | ||
| 1163 | 18년 전 | 1546 | ||
| 1162 |
|
18년 전 | 5664 | |
| 1161 |
이걸~어쩌나~
|
18년 전 | 2390 | |
| 1160 | 18년 전 | 1657 | ||
| 1159 | 18년 전 | 4700 | ||
| 1158 | 18년 전 | 2045 | ||
| 1157 | 18년 전 | 4839 | ||
| 1156 | 18년 전 | 3181 | ||
| 1155 | 18년 전 | 2123 | ||
| 1154 | 18년 전 | 1818 | ||
| 1153 |
BEST79
|
18년 전 | 2093 | |
| 1152 | 18년 전 | 1717 | ||
| 1151 | 18년 전 | 1834 | ||
| 1150 | 18년 전 | 1830 | ||
| 1149 |
inniskun
|
18년 전 | 2473 | |
| 1148 |
|
18년 전 | 3489 | |
| 1147 |
|
18년 전 | 5967 | |
| 1146 |
|
18년 전 | 3854 | |
| 1145 | 18년 전 | 3052 | ||
| 1144 | 18년 전 | 2124 | ||
| 1143 | 18년 전 | 2395 | ||
| 1142 | 18년 전 | 2183 | ||
| 1141 |
|
18년 전 | 2297 | |
| 1140 | 18년 전 | 2398 | ||
| 1139 | 18년 전 | 2835 | ||
| 1138 | 18년 전 | 2527 | ||
| 1137 | 18년 전 | 1984 | ||
| 1136 | 18년 전 | 3122 | ||
| 1135 | 18년 전 | 3583 | ||
| 1134 | 18년 전 | 3829 | ||
| 1133 |
자반고등어
|
18년 전 | 3330 | |
| 1132 | 18년 전 | 3375 | ||
| 1131 | 18년 전 | 2559 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기