位置: IT常识 - 正文

查询数据库空间(mysql和oracle)(如何查询数据库表空间)

编辑:rootadmin
查询数据库空间(mysql和oracle) Mysql版1、查看所有数据库容量大小-- 查看所有数据库容量大小SELECT table_schema AS '数据库', sum( table_rows ) AS '记录数', sum( TRUNCATE ( data_length / 1024 / 1024, 2 )) AS '数据容量(MB)', sum( TRUNCATE ( index_length / 1024 / 1024, 2 )) 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 / 1024, 2 ) AS '数据容量(MB)', TRUNCATE ( index_length / 1024 / 1024, 2 ) AS '索引容量(MB)' FROM information_schema.TABLES ORDER BY data_length DESC, index_length DESC;3、查看指定数据库容量大小SELECT table_schema AS '数据库', sum( table_rows ) AS '记录数', sum( TRUNCATE ( data_length / 1024 / 1024, 2 )) AS '数据容量(MB)', sum( TRUNCATE ( index_length / 1024 / 1024, 2 )) AS '索引容量(MB)' FROM information_schema.TABLES WHERE table_schema = '数据库名';4.查看指定数据库各表容量大小SELECT table_schema AS '数据库', table_name AS '表名', table_rows AS '记录数', TRUNCATE ( data_length / 1024 / 1024, 2 ) AS '数据容量(MB)', TRUNCATE ( index_length / 1024 / 1024, 2 ) AS '索引容量(MB)' FROM information_schema.TABLES WHERE table_schema = '数据库名' ORDER BY data_length DESC, index_length DESC;5.查看指定数据库各表信息SHOW TABLE STATUS;oracle版1、查看表所占的空间大小-- 不需要DBA权限SELECT SEGMENT_NAME TABLENAME,(BYTES/1024/1024) MB,RANK() OVER (PARTITION BY NULL ORDER BY BYTES DESC) RANK_ID //根据表大小进行排序FROM USER_SEGMENTSWHERE SEGMENT_TYPE='TABLE'-- 需要DBA权限,一般情况下很少会给这么高的权限,可以说这个权限基本没有,所以一般工作中不是DBA的人不会常用到这个命令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 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) bWHERE a.tablespace_name = b.tablespace_name3、查看回滚段名称及大小SELECT segment_name,tablespace_name, r.status, (initial_extent / 1024) initialextent, (next_extent / 1024) nextextent, max_extents, v.curext curextent FROM dba_rollback_segs r, v$rollstat v WHERE 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, status, COUNT(*) count# FROM all_objects GROUP BY owner, object_type, status; 7、查看数据库版本SELECT versionFROM product_component_version WHERE substr(product, 1, 6) = 'Oracle'; 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.STATUSFROM DBA_TABLESPACES T,DBA_DATA_FILES DWHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME ORDER BY TABLESPACE_NAME,FILE_NAME;oracle加强版一、查看表空间使用率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) bwhere a.tablespace_name = b.tablespace_nameorder by a.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(bytes) bytesfrom dba_data_filesgroup by tablespace_name) a,(select tablespace_name,sum(bytes) bytesfrom dba_free_spacegroup by tablespace_name) bwhere a.tablespace_name = b.tablespace_nameunion allselect 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) bytesfrom dba_temp_files group by tablespace_name) c,(select tablespace_name,sum(bytes_cached) bytes_usedfrom v$temp_extent_pool group by tablespace_name) dwhere c.tablespace_name = d.tablespace_name)order by tablespace_name5.查看具体表的占用空间大小--查看具体表的占用空间大小select * from (select t.tablespace_name,t.owner, t.segment_name, t.segment_type, sum(t.bytes / 1024 / 1024) mbfrom dba_segments twhere t.segment_type='TABLE'group by t.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 1000m autoextend on next 100m;3. 如果是temp临时表新增表空间会报错:

推荐整理分享查询数据库空间(mysql和oracle)(如何查询数据库表空间),希望有所帮助,仅作参考,欢迎阅读内容。

查询数据库空间(mysql和oracle)(如何查询数据库表空间)

文章相关热门搜索词:查看数据库空间使用情况命令,查看数据库空间使用情况命令,数据库存储空间查询,查询数据库表空间,查询数据库空间使用率,数据库空间查看,查询数据库空间大小,查询数据库空间oracle,内容如对您有帮助,希望把文章链接给更多的朋友!

0RA-03217: 变更TEMPORARY TABLESPACE 无效的选项 解决方法: datafile改为tempfile

alter tablespace TEMP01 add tempfile'/****' size 1000m autoextend on next 100m maxsize 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_propertieswhere 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 swhere p.name='db_block_size' and su.session_addr=se.saddr and s.hash_value=su.sqlhashand s.address=su.sqladdrorder by se.username,se.sid;--删除对应的'sid,serial#'alter system kill session 'sid,serial#'

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

--查看表空间是否具有自动扩展的能力 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;
本文链接地址:https://www.jiuchutong.com/zhishi/298385.html 转载请保留说明!

上一篇:【YOLOv7】主要改进点详解(yolov4参数设置)

下一篇:【蓝桥杯Web】第十四届蓝桥杯Web模拟赛 3 期 | 精品题解(上)(蓝桥杯b组2020)

  • 财务软件大概多少钱
  • 个税是按照实发工资计算吗
  • 股权转让给个人和公司的区别
  • 银行日记账期初余额写在什么科目
  • 政府补贴什么时候确认收入
  • 土地以租代卖,违法吗
  • 证券清算款是什么科目
  • 月末结转所有收入类账户
  • 增值税专用发票有效期是多长时间
  • 企业房产税如何计算缴纳
  • 关于增值税的问题有哪些
  • 资产处置损益和营业外收支的区别和联系
  • 汇票和本票之间在使用上有什么差别
  • 税费是哪个会计科目?
  • 加油可以吗
  • wind10激活密钥
  • 老毛桃u盘启动盘制作工具怎么安装win10系统 老毛桃u盘安装win10系统图文教程
  • linux关闭thp
  • 如何删除文档中多余的页
  • php 替换字符
  • w10的蜘蛛纸牌
  • i9是多少纳米的芯片
  • 付给他人押金的会计分录
  • 预收的购货款属于收入吗
  • 营改增项目
  • 什么情形不属于经警告无效人民警察可以使用武器的情形
  • 如何进行抵债资金管理
  • 递延所得税的计税基础
  • 一场雷雨还是一阵雷雨
  • 还在用夸克?这3款能安装插件的手机浏览器不香吗_Via_
  • 商业汇票贴现时贴现额的大小受贴现期长短的影响
  • 投影仪属于固定资产哪一类
  • 增值税发票可以作废重新开吗
  • php邮件发送类
  • 知名个人网站
  • github ci/cd
  • 压缩的命令
  • 营改增小规模纳税人可以进项税额扣除对吗
  • 营业执照贴印花税票吗
  • 小规模纳税人减免增值税会计处理
  • 异地预缴印花税怎么做账
  • 销售价格含税的会计分录
  • 视同销售是怎么回事?
  • 个税专项附加扣除什么意思
  • 企业固定电话费收费标准
  • 收到投资款如何做账务处理
  • 长期股权投资的账务处理
  • 投入产出法如何申报
  • 开票金额大于收入金额
  • 合理损耗怎么算
  • 行政事业单位福利费提取比例
  • 税票名称开错了有影响么
  • 驾驶员行车补贴
  • 投资款计入哪个科目
  • 劳务公司的工资表怎么做账
  • mysql where clause
  • mysql为什么很受大家青睐
  • mysql预编译原理
  • mac开机声音怎么取消
  • 装win7系统步骤
  • Linux系统root密码忘记怎么重置
  • win8.1无法启动
  • windows10 经典模式
  • kill命令用法
  • ios平台中glsl中shadow2DProjEXT函数的简单说明以及变换矩阵的小注意点
  • unity游戏之友利拟收购《刀塔传奇》发行商中清龙图
  • javascript数据结构
  • 第一次接触怎么形容
  • Node.js中的全局对象有
  • 微软早在1985年便首次使用了安卓上饱受争议的汉堡按钮
  • 微信小程序访问相册权限在哪里
  • node js教程
  • javascript in
  • jQuery+Ajax实现无刷新操作
  • nodejs递归创建目录
  • jquery动态添加div
  • Android调用系统截屏方法
  • 医保银行代扣是什么意思
  • 电子税务局怎么添加银行账户信息
  • 怎样打印护士资格证
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设