SELECT UPPER(F.TABLESPACE_NAME) "表空間名",
D.TOT_GROOTTE_MB "表空間大小(M)",
D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空間(M)",
TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),'990.99') || '%' "使用比",
F.TOTAL_BYTES "空閑空間(M)",
F.MAX_BYTES "最大塊(M)"
FROM (SELECT TABLESPACE_NAME,
ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
FROM SYS.DBA_FREE_SPACE
GROUP BY TABLESPACE_NAME) F,
(SELECT DD.TABLESPACE_NAME,
ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB
FROM SYS.DBA_DATA_FILES DD
GROUP BY DD.TABLESPACE_NAME) D
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
ORDER BY 1
B. Oracle中如何查詢所有表及其所使用的表空間
Oracle中查詢所有表及其所使用的表空間可以使用SQL語句:
select
Segment_Name,Sum(bytes)/1024/1024
From
User_Extents
Group
By
Segment_Name;
在資料庫管理員的日常工作中,應該經常查詢表空間的利用率,按照資料庫系統的具體情況估算表空間的增長量,當表空間的利用率超過90%時,要及時採取措施。
(2)資料庫表空間使用情況擴展閱讀
oracle一些其他表空間查詢方法介紹:
1、查詢oracle系統用戶的默認表空間和臨時表空間
select
default_tablespace,temporary_tablespace
from
dba_users;
2、查詢單張表的使用情況
select
segment_name,bytes
from
dba_segments
where
segment_name
=
'tablename'
and
owner
=
USER;
3、查詢所有用戶表使用大小的前三十名
select
*
from
(select
segment_name,bytes
from
dba_segments
where
owner
=
USER
order
by
bytes
desc
)
where
rownum
<=
30;
4、查看錶空間物理文件的名稱及大小
SELECT
tablespace_name,
file_id,
file_name,
round(bytes
/
(1024
*
1024),
0)
total_space
FROM
dba_data_files
ORDER
BY
tablespace_name;
C. db2中怎麼查看錶空間的使用情況
db2 connect to 資料庫名 db2 list tablespaces show detail 如果要查對應容器, db2 list tablespace containers for 表空間id
D. SQL Server 如何 查詢表空間使用情況和連接數情況
1.通過管理工具
開始->管理工具->性能(或者是運行裡面輸入
mmc)然後通過添加計數器添加
sql
的常用統計
然後在下面列出的項目裡面選擇用戶連接就可以時時查詢到資料庫的連接數了。不過此方法的話需要有訪問那台計算機的許可權,就是要通過windows賬戶登陸進去才可以添加此計數器。
2.通過系統表查詢
select
*
from
[master].[dbo].[sysprocesses]
where
[dbid]
in
(
select
[dbid]
from
[master].[dbo].[sysdatabases]
where
name='dbname'
)
dbname
是需要查看的資料庫,然後查詢出來的行數,就是當前的連接數。不過裡面還有一些別的狀態可以做參考用。
例如:連到master這個資料庫寫如下語句
select
*
from
sysprocesses
where
dbid
in
(select
dbid
from
sysdatabases
where
name='mydatabase')
將所有連接mydatabase這個資料庫的連接記錄都求出來。
sysprocesses這個表記錄所以連接到sql
server資料庫的連接。
3.通過系統的存儲過程來查找
sp_who
'username'
username
是當然登陸sql的用戶名,一般程序裡面都會使用一個username來登陸sql這樣通過這個用戶名就能查看到此用戶名登陸之後佔用的連接了。
如果不寫username,那麼返回的就是所有的連接。
E. 如何使用SQL語句查詢資料庫及表的空間容量
--1、查看錶空間的名稱及大小
select
t.tablespace_name,
round(sum(bytes/(1024*1024)),0)
ts_size
from
dba_tablespaces
t,
dba_data_files
d
where
t.tablespace_name
=
d.tablespace_name
group
by
t.tablespace_name;
--2、查看錶空間物理文件的名稱及大小
select
tablespace_name,
file_id,
file_name,
round(bytes/(1024*1024),0)
total_space
from
dba_data_files
order
by
tablespace_name;
3.查看所有表空間使用情況
select
b.file_id
文件ID號,
b.tablespace_name
表空間名,
b.bytes/1024/1024||'M'位元組數,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024||'M'
已使用,
sum(nvl(a.bytes,0))/1024/1024||'M'
剩餘空間,
round(100
-
sum(nvl(a.bytes,0))/(b.bytes)*100,2)||
'%'
佔用百分比
from
dba_free_space
a,dba_data_files
b
where
a.file_id=b.file_id
group
by
b.tablespace_name,b.file_id,b.bytes
order
by
b.file_id;
總有一款適合你!
F. 怎麼察看Oracle 資料庫表空間的使用情況
查看的方法和詳細的操作步驟如下:
1、首先,因為oracle在Linux系統下運行,所以必須連接到Linux系統,如下圖所示,然後進入下一步。
G. 資料庫有哪些表空間各個表空間的作用是什麼
一、系統表空間
在 MySQL 數據目錄下有一個名為 ibdata1 的文件,可以保存一張或者多張表。
923275 12M -rw-r----- 1 mysql mysql 12M 3月 18 10:42 ibdata1
這個文件就是 MySQL 的系統表空間文件,默認為 1 個,可以有多個,只需要在配置文件 my.cnf 裡面這樣定義即可。
innodb_data_file_path=ibdata1:200M;ibdata2:200M:autoextend:max:800M系統表空間不僅可以是文件系統組成的文件,也可以是非文件系統組成的磁碟塊,比如裸設備,定義也很簡單innodb_data_file_path=/dev/nvme0n1p1:3Gnewraw;/dev/nvme0n1p2:2Gnewraw
系統表空間里都有些啥內容?
具體內容包括:double writer buffer、 change buffer、數據字典(MySQL 8.0 之前)、表數據、表索引。
那 MySQL 為什麼現在主流版本默認都不是系統表空間?
究其原因,系統表空間有三個最大的缺點:原因 1:無法做到自動收縮磁碟空間,造成很大的空間浪費。即使它包含的表都被刪掉,這部分空間也不會自動釋放。
二、單表空間
單表空間不同於系統表空間,每個表空間和表是一一對應的關系,每張表都有自己的表空間。具體在磁碟上表現為後綴為 .ibd 的文件。比如表 t1,對應的表空間文件為 t1.ibd917107 96K -rw-r----- 1 mysql mysql 96K 3月 18 16:13 t1.ibd
單表空間如何應用到具體的表呢?
有兩種方式:方式 1:在配置文件中開啟。在配置文件中開啟單表空間設置參數 innodb_filer_per_table,這樣默認對當前庫下所有表開啟單表空間。innodb_file_per_table=1另外也可以直接建表時指定單表空間mysql> create table t1 (id int, r1 char(36)) tablespace innodb_file_per_table;
Query OK, 0 rows affected (0.04 sec)
單表空間除了解決之前說的系統表空間的幾個缺點外,還有其他的優點,詳細如下:
1. truncate table 操作比其他的任何錶空間都快;
2. 可以把不同的表按照使用場景指定在不同的磁碟目錄;
比如日誌表放在慢點的磁碟,把需要經常隨機讀的表放在 SSD 上等。
mysql> create table ytt_dedicated (id int) data directory = '/var/lib/mysql-files';
Query OK, 0 rows affected (0.04 sec)3. 可以用 optimize table 來收縮或者重建經常增刪改查的表。一般過程是這樣的:建立和原來表一樣的表結構和數據文件,把真實數據復制到臨時文件,再刪掉原始表定義和數據文件,最後把臨時文件的名字改為和原始表一樣的。
三、通用表空間
通用表空間先是出現在 MySQL Cluster 里,也就是 NDB 引擎。從 MySQL 5.7 引入到 InnoDB 引擎。通用表空間和系統表空間一樣,也是共享表空間。每個表空間可以包含一張或者多張表,也就是說通用表空間和表之間是一對多的關系。
H. 資料庫中的表空間有什麼用途
就相當於sqlserver里的資料庫 賬號都是在表空間里區分的
I. oracle查看索引表空間的使用情況
這個問題根據斷句的不同有兩種可能:
(1)索引 ——表空間的使用情況,我知道資料庫本身沒有索引表空間,但是如果我自己建立了一個表空間,通俗名稱叫做索引表空間呢?所以有索引表空間還是有可能的,只是可能性不大。
基本上查詢dba_free_space就能查到表空間的剩餘量,如果非要查詢用了百分之多少之類的,這張表經過計算就能得到。如果不想查這張表,也可以通過sys.sm$ts_avail, sys.sm$ts_used 和 sys.sm$ts_free 三張表聯合查詢得到。
(2)索引表——空間的使用情況,也就是說查的是索引佔用的空間的情況,這種可能性更大一點。
dba_serments裡面存有相關數據,其中bytes就是段的大小,如果指定segment_type='INDEX'那麼你查出的內容就是索引,每一行對應的bytes就是索引佔用的位元組數,除以1024的結果就是兆(MB)了,如果求所有的索引總共表空間的使用情況,那麼sum一下就可以了。
J. 怎麼查看資料庫表空間足不足oracle
這個方法很多吧,可以使用語句查詢,也可以使用oracle資料庫工具查看,還可以用EM。
我這有個自己寫的sql腳本,是平時自己看公司資料庫表空間狀態時用的。你可以參考下:
.查看所有表空間的碎片程度(值在30以下表示碎片很多)
select tablespace_name,sum(bytes),sum(free),sum(free)*100/sum(bytes) from (select
b.file_id file_ID,
b.tablespace_name tablespace_name,
b.bytes Bytes,
(b.bytes-sum(nvl(a.bytes,0))) used,
sum(nvl(a.bytes,0)) free,
sum(nvl(a.bytes,0))/(b.bytes)*100 Percent
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_id,b.bytes
order by b.file_id) group by tablespace_name order by sum(free)*100/sum(bytes);
查看錶空間是否自動擴展
select file_name,autoextensible,increment_by from dba_data_files;
表空間自動擴展
alter database datafile 'path:\datafile name' autoextend on next 1M maxsize 100M;
表空間大小
select tablespace_name,count(*),sum(blocks),sum(bytes)/1024/1024
from dba_data_files
group by tablespace_name;
使用情況
select df.tablespace_name "表空間名",totalspace "總空間M",freespace "剩餘空間M",round((1-freespace/totalspace)*100,2) "使用率%"
from
(select tablespace_name,round(sum(bytes)/1024/1024) totalspace
from dba_data_files
group by tablespace_name) df,
(select tablespace_name,round(sum(bytes)/1024/1024) freespace
from dba_free_space
group by tablespace_name) fs
where df.tablespace_name=fs.tablespace_name;