Как определить размер табличного пространства оракула 11g
У меня есть база данных с тремя таблицами. Мне нужно переместить исторически разделенные данные в другую схему. Теперь, когда я планирую создать новые "исторические" таблицы. Я не знаю, как измерить размер раздела и подразделов. Ты можешь мне помочь? Пожалуйста, дайте мне несколько советов.
Спасибо заранее. Лу
4 ответа
Следующий запрос может использоваться для определения табличного пространства и других параметров:
select df.tablespace_name "Tablespace",
totalusedspace "Used MB",
(df.totalspace - tu.totalusedspace) "Free MB",
df.totalspace "Total MB",
round(100 * ( (df.totalspace - tu.totalusedspace)/ df.totalspace)) "Pct. Free"
from (select tablespace_name,
round(sum(bytes) / 1048576) TotalSpace
from dba_data_files
group by tablespace_name) df,
(select round(sum(bytes)/(1024*1024)) totalusedspace,
tablespace_name
from dba_segments
group by tablespace_name) tu
where df.tablespace_name = tu.tablespace_name
and df.totalspace <> 0;
Источник: https://community.oracle.com/message/1832920
Для вашего случая, если вы хотите знать имя раздела и его размер, просто запустите этот запрос:
select owner,
segment_name,
partition_name,
segment_type,
bytes / 1024/1024 "MB"
from dba_segments
where owner = <owner_name>;
Одним из способов является использование ниже SQL запросов
--Size of All Table Space
--1. Used Space
SELECT TABLESPACE_NAME,TO_CHAR(SUM(NVL(BYTES,0))/1024/1024/1024, '99,999,990.99') AS "USED SPACE(IN GB)" FROM USER_SEGMENTS GROUP BY TABLESPACE_NAME
--2. Free Space
SELECT TABLESPACE_NAME,TO_CHAR(SUM(NVL(BYTES,0))/1024/1024/1024, '99,999,990.99') AS "FREE SPACE(IN GB)" FROM USER_FREE_SPACE GROUP BY TABLESPACE_NAME
--3. Both Free & Used
SELECT USED.TABLESPACE_NAME, USED.USED_BYTES AS "USED SPACE(IN GB)", FREE.FREE_BYTES AS "FREE SPACE(IN GB)"
FROM
(SELECT TABLESPACE_NAME,TO_CHAR(SUM(NVL(BYTES,0))/1024/1024/1024, '99,999,990.99') AS USED_BYTES FROM USER_SEGMENTS GROUP BY TABLESPACE_NAME) USED
INNER JOIN
(SELECT TABLESPACE_NAME,TO_CHAR(SUM(NVL(BYTES,0))/1024/1024/1024, '99,999,990.99') AS FREE_BYTES FROM USER_FREE_SPACE GROUP BY TABLESPACE_NAME) FREE
ON (USED.TABLESPACE_NAME = FREE.TABLESPACE_NAME);
выберите b.tablespace_name, tbs_size SizeGb, a.free_space FreeGb из (выберите tablespace_name, round (сумма (байтов) / 1024/1024/1024, 2) как free_space из группы dba_free_space по tablespace_name) a, (выберите tablespace_name, sum (байты) / 1024/1024/1024 как tbs_size из группы dba_data_files по tablespace_name) b где a.tablespace_name(+)=b.tablespace_name порядок на 1
Один из способов проверить размер табличного пространства в oracle - запустить этот запрос
SELECT TABLESPACE_NAME, ROUND (SUM (BYTES) / 1048576) "Total Size MB"
FROM DBA_DATA_FILES
GROUP BY TABLESPACE_NAME