发布时间:2026/7/2 16:32:37
oracle用户下对象碎片排查 检查用户下哪些表有碎片--How to Find Fragmentation for Tables and LOBs KB138882SETSERVEROUTPUTONSIZE UNLIMITEDSETLINESIZE200SETPAGESIZE1000SETVERIFYOFFDECLAREv_schema VARCHAR2(30):UPPER(schema_name);-- Variables for space usagev_unformatted_blocks NUMBER;v_unformatted_bytes NUMBER;v_fs1_blocks NUMBER;v_fs1_bytes NUMBER;v_fs2_blocks NUMBER;v_fs2_bytes NUMBER;v_fs3_blocks NUMBER;v_fs3_bytes NUMBER;v_fs4_blocks NUMBER;v_fs4_bytes NUMBER;v_full_blocks NUMBER;v_full_bytes NUMBER;-- Variables for summaryv_total_blocks NUMBER :0;v_total_fragmented_blocks NUMBER :0;v_fragmentation_percent NUMBER :0;-- Cursor for all tables in the schemaCURSORc_tablesISSELECTtable_nameFROMall_tablesWHEREownerv_schemaORDERBYtable_name;BEGINDBMS_OUTPUT.PUT_LINE();DBMS_OUTPUT.PUT_LINE(Fragmentation Analysis for Schema: ||v_schema);DBMS_OUTPUT.PUT_LINE();DBMS_OUTPUT.PUT_LINE(RPAD(Table Name,30)||LPAD(Unformatted,12)||LPAD(FS1,10)||LPAD(FS2,10)||LPAD(FS3,10)||LPAD(FS4,10)||LPAD(Full,10)||LPAD(Frag%,10));DBMS_OUTPUT.PUT_LINE(------------------------------------------------------------------);FORr_tableINc_tablesLOOPBEGIN-- Get space usage for the tableDBMS_SPACE.SPACE_USAGE(segment_ownerv_schema,segment_namer_table.table_name,segment_typeTABLE,unformatted_blocksv_unformatted_blocks,unformatted_bytesv_unformatted_bytes,fs1_blocksv_fs1_blocks,fs1_bytesv_fs1_bytes,fs2_blocksv_fs2_blocks,fs2_bytesv_fs2_bytes,fs3_blocksv_fs3_blocks,fs3_bytesv_fs3_bytes,fs4_blocksv_fs4_blocks,fs4_bytesv_fs4_bytes,full_blocksv_full_blocks,full_bytesv_full_bytes);-- Calculate fragmentation percentage (FS1-FS4 as fragmented)IF(v_full_blocksv_fs1_blocksv_fs2_blocksv_fs3_blocksv_fs4_blocks)0THENv_fragmentation_percent :ROUND((v_fs1_blocksv_fs2_blocksv_fs3_blocksv_fs4_blocks)/(v_full_blocksv_fs1_blocksv_fs2_blocksv_fs3_blocksv_fs4_blocks)*100,2);ELSEv_fragmentation_percent :0;ENDIF;-- Output table informationDBMS_OUTPUT.PUT_LINE(RPAD(r_table.table_name,30)||LPAD(v_unformatted_blocks,12)||LPAD(v_fs1_blocks,10)||LPAD(v_fs2_blocks,10)||LPAD(v_fs3_blocks,10)||LPAD(v_fs4_blocks,10)||LPAD(v_full_blocks,10)||LPAD(v_fragmentation_percent,10));-- Accumulate totalsv_total_blocks :v_total_blocksv_full_blocksv_fs1_blocksv_fs2_blocksv_fs3_blocksv_fs4_blocks;v_total_fragmented_blocks :v_total_fragmented_blocksv_fs1_blocksv_fs2_blocksv_fs3_blocksv_fs4_blocks;EXCEPTIONWHENOTHERSTHENDBMS_OUTPUT.PUT_LINE(Error analyzing table ||r_table.table_name||: ||SQLERRM);END;ENDLOOP;-- Calculate overall fragmentationIFv_total_blocks0THENv_fragmentation_percent :ROUND((v_total_fragmented_blocks/v_total_blocks)*100,2);ELSEv_fragmentation_percent :0;ENDIF;-- Output summaryDBMS_OUTPUT.PUT_LINE(------------------------------------------------------------------);DBMS_OUTPUT.PUT_LINE(TOTAL BLOCKS: ||v_total_blocks||, FRAGMENTED BLOCKS: ||v_total_fragmented_blocks||, FRAGMENTATION: ||v_fragmentation_percent||%);DBMS_OUTPUT.PUT_LINE();-- Additional recommendationsIFv_fragmentation_percent30THENDBMS_OUTPUT.PUT_LINE(WARNING: High fragmentation detected (30%). Consider reorganizing tables with high fragmentation.);DBMS_OUTPUT.PUT_LINE(Actions to consider:);DBMS_OUTPUT.PUT_LINE(1. ALTER TABLE ... MOVE for tables with high fragmentation);DBMS_OUTPUT.PUT_LINE(2. Export/Import for very large tables);DBMS_OUTPUT.PUT_LINE(3. Online table redefinition for minimal downtime);ELSIF v_fragmentation_percent10THENDBMS_OUTPUT.PUT_LINE(NOTE: Moderate fragmentation detected (10%). Monitor tables with high fragmentation.);ELSEDBMS_OUTPUT.PUT_LINE(NOTE: Fragmentation level is acceptable.);ENDIF;EXCEPTIONWHENOTHERSTHENDBMS_OUTPUT.PUT_LINE(Error: ||SQLERRM);END;/直接将这段代码保存为3.sql执行效果如下输入用户名A后查到一些表的碎片情况轻量级的碎片治理方法可能首选shrink space是否能收缩到指定大小呢可以先评估一下SETSERVEROUTPUTONDECLAREl_can_shrinkBOOLEAN;BEGIN-- 检查 SCOTT 用户下的 EMP 表是否适合收缩l_can_shrink :DBMS_SPACE.VERIFY_SHRINK_CANDIDATE(segment_ownerA,segment_nameTEST,segment_typeTABLE-- 也可以是 INDEX,SHRINK_TARGET_BYTES1073741824-- Shrink to 1GB);IFl_can_shrinkTHENDBMS_OUTPUT.PUT_LINE(该表适合进行 SHRINK 操作。);ELSEDBMS_OUTPUT.PUT_LINE(该表不适合进行 SHRINK 操作请检查。);ENDIF;END;/输出是否适合shrink需要注意的是别写错了用户名和表名否则会直接提示不适合其实是表不存在。表名写对了就提示最后再赠送一个纵向查看对象的碎片脚本(不如上面的直观且会在库里创建函数)-- more info at http://tanelpoder.comcreateFUNCTIONget_space_usage(ownerINVARCHAR2,object_nameINVARCHAR2,segment_typeINVARCHAR2,partition_nameINVARCHAR2DEFAULTNULL)RETURNsys.DBMS_DEBUG_VC2COLL PIPELINEDASufbl NUMBER;ufby NUMBER;fs1bl NUMBER;fs1by NUMBER;fs2bl NUMBER;fs2by NUMBER;fs3bl NUMBER;fs3by NUMBER;fs4bl NUMBER;fs4by NUMBER;fubl NUMBER;fuby NUMBER;BEGINDBMS_SPACE.SPACE_USAGE(owner,object_name,segment_type,ufbl,ufby,fs1bl,fs1by,fs2bl,fs2by,fs3bl,fs3by,fs4bl,fs4by,fubl,fuby,partition_name);PIPEROW(Full blocks /MB ||TO_CHAR(fubl,999999999)|| ||TO_CHAR(fuby/1048576,999999999));PIPEROW(Unformatted blocks/MB ||TO_CHAR(ufbl,999999999)|| ||TO_CHAR(ufby/1048576,999999999));PIPEROW(Free Space 0-25% ||TO_CHAR(fs1bl,999999999)|| ||TO_CHAR(fs1by/1048576,999999999));PIPEROW(Free Space 25-50% ||TO_CHAR(fs2bl,999999999)|| ||TO_CHAR(fs2by/1048576,999999999));PIPEROW(Free Space 50-75% ||TO_CHAR(fs3bl,999999999)|| ||TO_CHAR(fs3by/1048576,999999999));PIPEROW(Free Space 75-100% ||TO_CHAR(fs4bl,999999999)|| ||TO_CHAR(fs4by/1048576,999999999));ENDget_space_usage;col frag_infofora50selectCOLUMN_VALUEasfrag_infofromtable(get_space_usage(A,TE,TABLE));其他参考https://blog.csdn.net/x6_9x/article/details/50596589https://www.cnblogs.com/shunqian/p/17604590.html

相关新闻

2026/7/2 15:32:35

嵌入式高精度电压监测系统设计与实现

1. 项目背景与核心价值 在嵌入式系统开发中,精确的电压管理一直是个让人头疼的问题。我最近在一个工业控制项目中,就遇到了需要实时监测和调整多路电压的需求。传统的解决方案要么精度不够,要么响应速度慢,要么成本太高。经过反复…

2026/7/2 15:32:35

别再手动搬运了:搭个企微 API 接口,让品牌技术资产自动落盘

在推进企业私域数据资产化、构建长效服务知识库或技术存证系统时,很多技术团队依然在依靠人工定期导出聊天记录、手动搬运或者用简单的脚本跑批导出文本。 这种依赖人工定期维护的模式,在真实的生产环境中存在明显的底层缺陷: 网络通信时序断…

2026/7/2 17:32:38

弱到强泛化:用弱模型监督强AI的工程实践与PGR评估

1. 项目概述:当“老师”比学生还弱,怎么教出顶尖高手?你有没有想过这样一个场景:让一个刚上高中的学生,去给清华计算机系的博士生讲算法课?听起来荒谬,但这就是当前AI对齐(Alignment…

2026/7/2 17:32:38

文本驱动的跨模态中枢架构:从语义锚定到工业级多模态对齐

1. 项目概述:当文字不再只是文字 “From Text to Beyond Words”——这个标题乍看像一句诗意的宣言,实则精准锚定了当前内容生成与人机交互领域最前沿的实践转向。它不是在说“把文字变成别的东西”,而是在追问:当文本作为信息载体…

2026/7/2 17:32:38

IS31FL3731与PIC18LF45K80实现LED矩阵控制详解

1. IS31FL3731与PIC18LF45K80的硬件协同架构在LED控制领域,IS31FL3731是一款被广泛采用的矩阵驱动芯片,而PIC18LF45K80作为Microchip旗下的经典微控制器,二者的组合能够构建出高性能的LED显示系统。IS31FL3731通过I2C接口与主控芯片通信&…

2026/7/2 17:32:38

终极指南:如何使用SysDVR将Switch游戏画面投屏到电脑

终极指南:如何使用SysDVR将Switch游戏画面投屏到电脑 【免费下载链接】SysDVR Stream switch games to your PC via USB or network 项目地址: https://gitcode.com/gh_mirrors/sy/SysDVR 你是否曾梦想将任天堂Switch的游戏画面实时投屏到电脑大屏幕上&#…

2026/7/2 17:32:38

手把手教你集成商品条码查询API:从原理到实战

引言:为什么需要条码查询API? 据统计,全球每天有超过60亿次条码扫描,从超市收银到仓库盘点,条码是商品世界的“身份证”。对于开发者而言,如果能通过API快速获取条码对应的商品名称、品牌、规格甚至实时价…

2026/7/2 16:32:37

LangChain中token管理:大模型应用的资源精算核心

1. 项目概述:这不是LangChain的“第三课”,而是你真正开始读懂大模型交互逻辑的分水岭 “Tokens and Models: Understanding LangChain 🦜️🔗 Part:3”——这个标题里藏着一个被绝大多数初学者忽略的关键信号:它不是按…

2026/7/2 0:32:22

基于LARA-R6001与PIC18LF46K42的VoLTE通信平台开发指南

1. 4G LTE VoLTE平台开发概述在物联网和移动通信技术快速发展的今天,构建自主可控的4G LTE VoLTE通信平台成为许多开发者的需求。LARA-R6001是一款高性能的4G LTE Cat 1模块,而PIC18LF46K42则是Microchip公司推出的低功耗8位单片机,两者的结合…

2026/7/2 0:32:22

AI 辅助:UI 色彩层级设计:颜色不是越多越有表现力

AI 辅助:UI 色彩层级设计:颜色不是越多越有表现力 一、色彩系统先解决层级,再表达情绪 UI 色彩设计的关键不是使用更多颜色,而是建立清晰层级。颜色承担品牌、状态、反馈和信息分组等职责。如果每个区域都使用高饱和色&#xff0c…

2026/7/2 0:32:22

ASM330LHH与TM4C123GH6PZ运动跟踪系统设计

1. 运动跟踪技术的现状与挑战在当今的智能设备领域,运动跟踪技术正经历着前所未有的变革。从智能手机到可穿戴设备,从工业机器人到虚拟现实系统,精确的运动感知能力已成为这些设备"理解"物理世界的基础。然而,要实现高精…

2026/7/2 1:27:35

3个高效策略:快速掌握Axure中文界面配置

3个高效策略:快速掌握Axure中文界面配置 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在为Axure RP的英文界面感…