테이블,컬럼 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에서 이동 됨]
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 1930 | 17년 전 | 3005 | ||
| 1929 | 17년 전 | 1879 | ||
| 1928 | 17년 전 | 3993 | ||
| 1927 | 17년 전 | 1411 | ||
| 1926 |
지엔소프트
|
17년 전 | 1128 | |
| 1925 |
보드타는찌니
|
17년 전 | 1244 | |
| 1924 |
choijinhee
|
17년 전 | 1126 | |
| 1923 | 17년 전 | 1389 | ||
| 1922 | 17년 전 | 1747 | ||
| 1921 | 17년 전 | 2340 | ||
| 1920 | 17년 전 | 2415 | ||
| 1919 | 17년 전 | 1420 | ||
| 1918 | 17년 전 | 1168 | ||
| 1917 | 17년 전 | 2440 | ||
| 1916 | 17년 전 | 2871 | ||
| 1915 |
|
17년 전 | 3237 | |
| 1914 | 17년 전 | 3174 | ||
| 1913 | 17년 전 | 2340 | ||
| 1912 | 17년 전 | 3756 | ||
| 1911 | 17년 전 | 3185 | ||
| 1910 | 17년 전 | 5506 | ||
| 1909 | 17년 전 | 2659 | ||
| 1908 | 17년 전 | 1862 | ||
| 1907 | 17년 전 | 1935 | ||
| 1906 | 17년 전 | 1777 | ||
| 1905 | 17년 전 | 1707 | ||
| 1904 | 17년 전 | 2774 | ||
| 1903 | 17년 전 | 1900 | ||
| 1902 | 17년 전 | 1585 | ||
| 1901 | 17년 전 | 2074 | ||
| 1900 |
stuartkim
|
17년 전 | 1140 | |
| 1899 | 17년 전 | 1668 | ||
| 1898 | 17년 전 | 2883 | ||
| 1897 | 17년 전 | 2127 | ||
| 1896 | 17년 전 | 1821 | ||
| 1895 | 17년 전 | 2037 | ||
| 1894 | 17년 전 | 1325 | ||
| 1893 | 17년 전 | 1718 | ||
| 1892 | 17년 전 | 1216 | ||
| 1891 | 17년 전 | 1781 | ||
| 1890 | 17년 전 | 1808 | ||
| 1889 | 17년 전 | 1042 | ||
| 1888 | 17년 전 | 3136 | ||
| 1887 | 17년 전 | 4317 | ||
| 1886 | 17년 전 | 2468 | ||
| 1885 | 17년 전 | 7476 | ||
| 1884 | 17년 전 | 3840 | ||
| 1883 | 17년 전 | 4172 | ||
| 1882 | 17년 전 | 2430 | ||
| 1881 | 17년 전 | 2890 | ||
| 1880 | 17년 전 | 3639 | ||
| 1879 | 17년 전 | 4007 | ||
| 1878 | 17년 전 | 3167 | ||
| 1877 | 17년 전 | 3150 | ||
| 1876 | 17년 전 | 3299 | ||
| 1875 | 17년 전 | 2466 | ||
| 1874 | 17년 전 | 2059 | ||
| 1873 | 17년 전 | 3110 | ||
| 1872 | 17년 전 | 3260 | ||
| 1871 | 17년 전 | 4614 | ||
| 1870 | 17년 전 | 1594 | ||
| 1869 | 17년 전 | 2619 | ||
| 1868 | 17년 전 | 2692 | ||
| 1867 | 17년 전 | 1903 | ||
| 1866 | 17년 전 | 2221 | ||
| 1865 | 17년 전 | 1841 | ||
| 1864 | 17년 전 | 2372 | ||
| 1863 | 17년 전 | 3777 | ||
| 1862 | 17년 전 | 3897 | ||
| 1861 | 17년 전 | 2083 | ||
| 1860 | 17년 전 | 1362 | ||
| 1859 | 17년 전 | 1498 | ||
| 1858 |
|
17년 전 | 1652 | |
| 1857 | 17년 전 | 1634 | ||
| 1856 |
보드타는찌니
|
17년 전 | 1398 | |
| 1855 | 17년 전 | 1544 | ||
| 1854 |
|
17년 전 | 1361 | |
| 1853 | 17년 전 | 1850 | ||
| 1852 | 17년 전 | 2750 | ||
| 1851 | 17년 전 | 1851 | ||
| 1850 |
|
17년 전 | 1404 | |
| 1849 |
|
17년 전 | 1692 | |
| 1848 |
|
17년 전 | 2331 | |
| 1847 | 17년 전 | 1946 | ||
| 1846 |
은사시나무
|
17년 전 | 1266 | |
| 1845 |
갈색야생마
|
17년 전 | 5906 | |
| 1844 |
갈색야생마
|
17년 전 | 3285 | |
| 1843 |
갈색야생마
|
17년 전 | 3178 | |
| 1842 |
갈색야생마
|
17년 전 | 2590 | |
| 1841 |
갈색야생마
|
17년 전 | 2772 | |
| 1840 |
갈색야생마
|
17년 전 | 2720 | |
| 1839 |
갈색야생마
|
17년 전 | 3226 | |
| 1838 |
갈색야생마
|
17년 전 | 2353 | |
| 1837 |
갈색야생마
|
17년 전 | 2471 | |
| 1836 |
갈색야생마
|
17년 전 | 2533 | |
| 1835 |
갈색야생마
|
17년 전 | 2526 | |
| 1834 |
갈색야생마
|
17년 전 | 2669 | |
| 1833 |
갈색야생마
|
17년 전 | 3189 | |
| 1832 |
갈색야생마
|
17년 전 | 2702 | |
| 1831 |
갈색야생마
|
17년 전 | 1427 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기