>데이터 베이스 >Oracle >Oracle은 테이블 공간 사용량을 확인하고 전체 인스턴스 문제를 해결합니다.

Oracle은 테이블 공간 사용량을 확인하고 전체 인스턴스 문제를 해결합니다.

WBOY
WBOY앞으로
2022-07-29 15:25:544248검색

이 기사에서는 Oracle에 대한 관련 지식을 제공합니다. Oralce를 일상적으로 사용하면서 가장 흔히 발생하는 문제는 Oralce의 테이블 공간이 가득 차고 데이터를 쓸 수 없으며 오류 메시지가 보고된다는 것입니다. . 모두에게 도움이 되기를 바랍니다.

Oracle은 테이블 공간 사용량을 확인하고 전체 인스턴스 문제를 해결합니다.

추천 튜토리얼: "Oracle Video Tutorial"

1. 테이블 공간 사용량 확인

1. 데이터베이스 테이블 공간 파일 확인:

--查看数据库表空间文件
select * from dba_data_files;

2.
--查看所有表空间的总容量
select dba.TABLESPACE_NAME, sum(bytes)/1024/1024 as MB  
from dba_data_files dba 
group by dba.TABLESPACE_NAME;

3. 데이터베이스 테이블스페이스 사용량 확인

--查看数据库表空间使用率
select total.tablespace_name,round(total.MB, 2) as Total_MB,round(total.MB - free.MB, 2) as Used_MB,round((1-free.MB / total.MB)* 100, 2) || '%' as Used_Pct 
from (
select tablespace_name, sum(bytes) /1024/1024 as MB 
from dba_free_space group by tablespace_name) free,
(select tablespace_name, sum(bytes) / 1024 / 1024 as MB 
from dba_data_files group by tablespace_name) total     
where free.tablespace_name = total.tablespace_name 
order by used_pct desc;

4.1. 테이블스페이스 전체 크기, 사용량, 남은 공간 확인

--查看表空间总大小、使用率、剩余空间
select a.tablespace_name, total, free, total-free as used, substr(free/total * 100, 1, 5) as "FREE%", substr((total - free)/total * 100, 1, 5) as "USED%"
from
(select tablespace_name, sum(bytes)/1024/1024 as total from dba_data_files group by tablespace_name) a,
(select tablespace_name, sum(bytes)/1024/1024 as free from dba_free_space group by tablespace_name) b
where a.tablespace_name = b.tablespace_name
order by a.tablespace_name

4.2 테이블스페이스 사용량 확인(임시 임시 테이블스페이스 포함)

--查看表空间使用率(包含临时表空间)
select * from (
Select a.tablespace_name,
(a.bytes- b.bytes) "表空间使用大小(BYTE)",
a.bytes/(1024*1024*1024) "表空间大小(GB)",
b.bytes/(1024*1024*1024) "表空间剩余大小(GB)",
(a.bytes- b.bytes)/(1024*1024*1024) "表空间使用大小(GB)",
to_char((1 - b.bytes/a.bytes)*100,'99.99999') || '%' "使用率"
from (select tablespace_name,
sum(bytes) bytes
from dba_data_files
group by tablespace_name) a,
(select tablespace_name,
sum(bytes) bytes
from dba_free_space
group by tablespace_name) b
where a.tablespace_name = b.tablespace_name
union all
select c.tablespace_name,
d.bytes_used "表空间使用大小(BYTE)",
c.bytes/(1024*1024*1024) "表空间大小(GB)",
(c.bytes-d.bytes_used)/(1024*1024*1024) "表空间剩余大小(GB)",
d.bytes_used/(1024*1024*1024) "表空间使用大小(GB)",
to_char(d.bytes_used*100/c.bytes,'99.99999') || '%' "使用率"
from
(select tablespace_name,sum(bytes) bytes
from dba_temp_files group by tablespace_name) c,
(select tablespace_name,sum(bytes_cached) bytes_used
from v$temp_extent_pool group by tablespace_name) d
where c.tablespace_name = d.tablespace_name
)
order by tablespace_name

5 .특정 테이블 점유 공간 크기 확인

--查看具体表的占用空间大小
select * from (
select t.tablespace_name,t.owner, t.segment_name, t.segment_type, sum(t.bytes / 1024 / 1024) mb
from dba_segments t
where t.segment_type='TABLE'
group by t.tablespace_name,t.OWNER, t.segment_name, t.segment_type
) t
order by t.mb desc

2. 테이블스페이스 파일 크기 확장 또는 증가

1. 테이블스페이스의 dbf 데이터 파일 할당 공간 크기 변경

alter database datafile ‘...\system_01.dbf' autoextend on;
alter database datafile ‘...\system_01.dbf' resize 1024M;

2.1 새 데이터 파일 추가 (테이블 공간이 32G로 꽉 차서 확장할 수 없으면 늘리세요) 테이블 공간 파일)

alter tablespace SYSTEM add datafile '/****' size 1000m autoextend on next 100m;

2.2 임시 임시 테이블에 새 테이블 공간이 추가되면 오류가 보고됩니다.

0RA -03217: TEMPORARY TABLESPACE를 변경하는 잘못된 옵션

솔루션: 데이터 파일을 임시 파일로 변경

alter tablespace TEMP01 add tempfile'/****' size 1000m autoextend on next 100m;

임시 임시 테이블 공간에 사용됨 비율 전체 문제

임시 테이블 공간의 주요 목적은 데이터베이스가 작업을 수행할 때 임시 컴퓨팅 공간을 제공하는 것입니다. 작업 정렬, 인덱스 관리, 뷰 액세스 등 작업이 완료되면 시스템이 자동으로 정리하지만 때로는 사용할 수 없는 임시 세그먼트가 발생하여 TEMP 테이블 공간이 거의 가득 차 있습니다.

주로 다음 상황에서 임시 테이블 공간이 증가합니다.

1, 정렬 기준 또는 그룹 기준(주요 부분에 대한 디스크 정렬 계정)

2, 인덱스 생성 및 재생성

3;

4. 합집합 및 교차 정렬-병합 조인

5. 일부 예외로 인해 TEMP가 급등할 수도 있습니다.

해결책 1: 위의 방법을 사용하여 temp에 테이블스페이스 파일을 추가합니다

해결책 2: 서버 리소스 공간이 제한되어 있는 경우 새 임시 테이블스페이스를 다시 만들어 현재 테이블스페이스를 대체합니다.

--1.查看当前的数据库默认表空间:
select * from database_properties
where property_name='DEFAULT_TEMP_TABLESPACE';

--2.创建新的临时表空间
create temporary tablespace TEMP01 tempfile 
'/home/temp01.dbf' size 31G;

--3.更改默认临时表空间
alter database default temporary tablespace TEMP01;

--4.删除原来的临时表空间
drop tablespace TEMP02 including contents and datafiles;

--如果删除原来临时表空间报错ORA-60100:由于排序段,已阻止删除表空间...
--(说明有语句正在使用原来的临时表空间,需要将其kill掉再删除,此语句多为排序的语句)
--查询语句
Select se.username,se.sid,se.serial#,su.extents,su.blocks*to_number(rtrim(p.value))as Space,
tablespace,segtype,sql_text
from v$sort_usage su,v$parameter p,v$session se,v$sql s
where p.name='db_block_size' and su.session_addr=se.saddr and s.hash_value=su.sqlhash
and s.address=su.sqladdr
order by se.username,se.sid;

--删除对应的'sid,serial#'
alter system kill session 'sid,serial#'

첨부: 테이블 보기 space 자동 확장이 가능한가요

--查看表空间是否具有自动扩展的能力     
SELECT T.TABLESPACE_NAME,D.FILE_NAME,     
D.AUTOEXTENSIBLE,D.BYTES,D.MAXBYTES,D.STATUS     
FROM DBA_TABLESPACES T,DBA_DATA_FILES D     
WHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME     
 ORDER BY TABLESPACE_NAME,FILE_NAME;

추천 튜토리얼: "

Oracle Video Tutorial

"

위 내용은 Oracle은 테이블 공간 사용량을 확인하고 전체 인스턴스 문제를 해결합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 jb51.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제