# oracle object 조회
-- object 조회
select * from ALL_OBJECTS; -- 또는 dba_objects 환경에 맞게 조회
1
2
2
-- table 조회
select * from ALL_TABLES;
1
2
2
-- index 조회
select * from ALL_IND_COLUMNS;
1
2
2
-- column 조회
select * from ALL_TAB_COLUMNS;
1
2
2
-- comment 조회
select * from ALL_COL_COMMENTS;
1
2
2
-- dblink 조회
select * from ALL_DB_LINKS;
1
2
2
-- synonym 조회
SELECT * FROM ALL_SYNONYMS;
1
2
2
-- procedure, function 소스 조회(조건은 알아서)
SELECT *
FROM dba_SOURCE
WHERE owner NOT IN ( 'SYS', 'ORACLE_OCM', 'SYSTEM', 'DBSNMP','WMSYS','EXFSYS')
AND TEXT LIKE '%@DL_PRD%';
1
2
3
4
5
2
3
4
5
-- 오라클 버전 확인
select * from v$version;
1
2
2
-- 오라클 RAC 확인
select * From v$option where parameter ='Real Application Clusters';
1
2
2
# synonym DBlink
http://www.gurubee.net/lecture/1560 (opens new window)
https://myjamong.tistory.com/179 (opens new window)
dblink를 synonym 으로 감싸서 사용하기도 한다. 예전에 유행하던 스타일이라고 한다.. 아무튼 요즘은 걷어내는 추세!
# 시퀀스
# 시퀀스 조정
- 드롭하고 새로 생성
- 증분값 조정
ALTER SEQUENCE [변경 대상 시퀀스] INCREMENT BY 289462;
1
블로그 검색해보니 대부분 증분값 변경해서 조절하는거 같다. 하지만 일개 개발자에게는 권한이 없음
- select 시퀀스.nextval connect by level
select 문에 connect by level 써서 올려줘도 되긴 하는데 툴에서 200번 돌고 멈춰버림
- using pl/sql loop
Best way to reset an Oracle sequence to the next value in an existing column (opens new window)
DECLARE
v_seq NUMBER(10) := 0;
BEGIN
FOR i IN 1 .. 10 LOOP
SELECT GS_SCM_BRAND_REQ_SEQ.nextval INTO v_seq FROM dual;
END LOOP;
END;
1
2
3
4
5
6
7
2
3
4
5
6
7
야매로 조절하기 최고의 방법인듯 만번도 거뜬함.
# [ORACLE] Sequence 증가 이상 - Cache (Last Number와 Currval 값 차이)
https://doughman.tistory.com/11 (opens new window)
https://bae9086.tistory.com/297 (opens new window)
https://subbak2.tistory.com/16 (opens new window)
CACHE 옵션은 원래 그 용도가 순차적으로 시퀀스를 증가시키는 것에 중점을 둔 기능이 아니라, 성능을 위해 미리 숫자만큼 캐시해놓는다라는 의미가 강한 옵션이다. LAST NUMBER 조회하면 CACHE 만큼 메모리에 할당된 시퀀스 넘버가 보임.
# ORACLE RAC
- 여러 개의 Instance가 하나의 Database를 엑세스
https://myalpaca.tistory.com/17 (opens new window)