怎么查询mysql和oracle数据库空间

网友投稿 768 2023-10-26

怎么查询mysql和***数据库空间

本篇内容主要讲解“怎么查询mysql和***数据库空间”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么查询mysql和***数据库空间”吧!

怎么查询mysql和***数据库空间

Mysql版

1、查看所有数据库容量大小-- 查看所有数据库容量大小 SELECT     table_schema AS 数据库,     sum( table_rows ) AS 记录数,     sum(     TRUNCATE ( data_length / 1024 / 10242 )) AS 数据容量(MB),     sum(     TRUNCATE ( index_length / 1024 / 10242 )) AS 索引容量(MB)  FROM     information_schema.TABLES  GROUP BY     table_schema  ORDER BY     sum( data_length ) DESC,     sum( index_length )DESC;2、查看所有数据库各表容量大小SELECT     table_schema AS 数据库,     table_name AS 表名,     table_rows AS 记录数,     TRUNCATE ( data_length / 1024 / 10242 ) AS 数据容量(MB),     TRUNCATE ( index_length / 1024 / 10242 ) AS 索引容量(MB)  FROMinformation_schema.TABLESORDER BY     data_length DESC,     index_length DESC;3、查看指定数据库容量大小SELECTtable_schemaAS 数据库,     sum( table_rows ) AS 记录数,     sum(     TRUNCATE ( data_length / 1024 / 10242 )) AS 数据容量(MB),     sum(     TRUNCATE( index_length /1024 / 10242 )) AS 索引容量(MB)  FROM     information_schema.TABLES  WHERE     table_schema = 数据库名;4.查看指定数据库各表容量大小SELECT     table_schema AS 数据库,     table_name AS 表名,     table_rows AS 记录数,     TRUNCATE( data_length /1024 / 10242 ) AS 数据容量(MB),     TRUNCATE ( index_length / 1024 / 10242 ) AS 索引容量(MB)  FROMinformation_schema.TABLESWHERE     table_schema = 数据库名  ORDER BY     data_length DESC,     index_length DESC;5.查看指定数据库各表信息SHOW TABLE STATUS;

***版

1、查看表所占的空间大小--  不需要DBA权限 SELECT SEGMENT_NAME TABLENAME,(BYTES/1024/1024) MB ,RANK() OVER (PARTITION BY NULL ORDER BY BYTES DESC) RANK_ID  //根据表大小进行排序 FROM USER_SEGMENTS WHERESEGMENT_TYPE=TABLE -- 需要DBA权限,一般情况下很少会给这么高的权限,可以说这个权限基本没有,所以一般工作中不是DBA的人不会常用到这个命令 SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size  FROM dba_tablespaces t, dba_data_files d  WHEREt.tablespace_name = d.tablespace_nameGROUP BY t.tablespace_name;2、查看表空间的使用情况SELECT a.tablespace_name "表空间名称",        total / (1024 * 1024"表空间大小(M)",        free / (1024 * 1024"表空间剩余大小(M)",        (total - free) / (1024 * 1024 ) "表空间使用大小(M)",        total / (1024 * 1024 * 1024"表空间大小(G)",        free / (1024 * 1024 * 1024"表空间剩余大小(G)",        (total - free) / (1024 * 1024 * 1024"表空间使用大小(G)",        round((total - free) / total, 4) * 100 "使用率 %" FROM (SELECT tablespace_name, SUM(bytes) free       FROM dba_free_space       GROUP BY tablespace_name) a,      (SELECT tablespace_name, SUM(bytes) total       FROM dba_data_files       GROUP BY tablespace_name) b WHERE a.tablespace_name = b.tablespace_name3、查看回滚段名称及大小SELECTsegment_name,  tablespace_name,  r.status,  (initial_extent /1024) initialextent,  (next_extent /1024) nextextent,  max_extents,  v.curext curextent  FROMdba_rollback_segs r, v$rollstat vWHERE r.segment_id = v.usn(+)  ORDER BY segment_name;

4、查看控制文件

SELECT NAME FROM v$controlfile;5、查看日志文件SELECT MEMBER FROM v$logfile;6、查看数据库对象SELECT owner, object_type, statusCOUNT(*) count FROMall_objectsGROUP BY owner, object_type, status;7、查看数据库版本SELECT version  FROM product_component_version  WHERE substr(product,16) = ***;8、查看数据库的创建日期和归档方式SELECT created, log_mode, log_mode FROM v$database;9、查看表空间是否具有自动扩展的能力SELECT T.TABLESPACE_NAME,D.FILE_NAME, D.AUTOEXTENSIBLE,D.BYTES,D.MAXBYTES,D.STATUS FROMDBA_TABLESPACES T,DBA_DATA_FILES DWHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME  ORDER BYTABLESPACE_NAME,FILE_NAME;

***加强版

一、查看表空间使用率1.查看数据库表空间文件:--查看数据库表空间文件 select * from dba_data_files;2.查看所有表空间的总容量:--查看所有表空间的总容量 select dba.TABLESPACE_NAME, sum(bytes)/1024/1024 as MB   from dba_data_files dba  group bydba.TABLESPACE_NAME;3.查看数据库表空间使用率--查看数据库表空间使用率 select total.tablespace_name,round(total.MB, 2as Total_MB,round(total.MB - free.MB,2as Used_MB,round((1-free.MB / total.MB)* 1002) || % 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      wherefree.tablespace_name = total.tablespace_nameorder by used_pct desc;4.1.查看表空间总大小、使用率、剩余空间--查看表空间总大小、使用率、剩余空间 selecta.tablespace_name, total, free, total-freeas used, substr(free/total * 10015as "FREE%"substr((total - free)/total *10015as "USED%" from (select tablespace_name, sum(bytes)/1024/1024 as total from dba_data_files group bytablespace_name) a, (select tablespace_name, sum(bytes)/1024/1024 as free from dba_free_space group bytablespace_name) bwhere a.tablespace_name = b.tablespace_name order bya.tablespace_name4.2.查看表空间使用率(包含temp临时表空间)--查看表空间使用率(包含临时表空间) 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(bytesbytes from dba_data_files group bytablespace_name) a, (select tablespace_name, sum(bytesbytes from dba_free_space group by tablespace_name) b wherea.tablespace_name = b.tablespace_nameunion 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(bytesbytes from dba_temp_files group bytablespace_name) c, (select tablespace_name,sum(bytes_cached) bytes_used from v$temp_extent_pool group bytablespace_name) dwhere c.tablespace_name = d.tablespace_name ) order bytablespace_name5.查看具体表的占用空间大小--查看具体表的占用空间大小 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 byt.tablespace_name,t.OWNER, t.segment_name, t.segment_type ) torder by t.mb desc二、扩展大小或增加表空间文件1.更改表空间的dbf数据文件分配空间大小alter database datafile ‘...\system_01.dbf autoextend on; alter database datafile ‘...\system_01.dbf resize 1024M;2. 为表空间新增一个数据文件(表空间满32G不能扩展则增加表空间文件)alter tablespace SYSTEM add datafile /**** size 1000autoextend on next 100m;3. 如果是temp临时表新增表空间会报错:

0RA-03217: 变更TEMPORARY TABLESPACE 无效的选项

解决方法: datafile改为tempfilealter tablespace TEMP01 add tempfile/**** size 1000autoextend on next 100maxsize 10000m

针对temp临时表空间使用率爆满问题

临时表空间主要用途是在数据库进行排序运算、管理索引、访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理,但有些时候我们会遇到临时段没有被释放,TEMP表空间几乎满使用率情况;

引起临时表空间增大主要使用在以下几种情况:

1、order by or group by (disc sort占主要部分);

2、索引的创建和重创建;

3、distinct操作;

4、union & intersect & minus sort-merge joins;

5、Analyze 操作;

6、有些异常也会引起TEMP的暴涨。

解决方法一:用上述方法给temp增加表空间文件

解决方法二:在服务器资源空间有限的情况下,重新建立新的临时表空间替换当前的表空间--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_textfrom v$sort_usage su,v$parameter p,v$session se,v$sql s where p.name=db_block_size andsu.session_addr=se.saddrand s.hash_value=su.sqlhash and s.address=su.sqladdr order by se.username,se.sid;   --删除对应的sid,serial# alter system kill session sid,serial#

附:查看表空间是否具有自动扩展的能力

--查看表空间是否具有自动扩展的能力      SELECTT.TABLESPACE_NAME,D.FILE_NAME,      D.AUTOEXTENSIBLE,D.BYTES,D.MAXBYTES,D.STATUSFROMDBA_TABLESPACES T,DBA_DATA_FILES DWHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME       ORDER BY TABLESPACE_NAME,FILE_NAME;

到此,相信大家对“怎么查询mysql和***数据库空间”有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mysql prepare的作用是什么
下一篇:你是如何解决分布式系统的数据一致性问题的?教你6种分布式系统数据一致性方案
相关文章