统计信息锁住导致收集统计信息失败引起sql执行异常
admin
2023-04-15 06:41:28
0

这个是老生产谈的事情,统计信息不准确导致sql执行异常,此次记录的主要是表的统计信息被锁住导致无法正常收集统计信息导致sql执行异常:
收集表的统计信息:
SQL> exec DBMS_STATS.GATHER_TABLE_STATS(OWNNAME => 'crmdb', TABNAME => 'T_ORDER_DELIVERY', CASCADE => TRUE);
BEGIN DBMS_STATS.GATHER_TABLE_STATS(OWNNAME => 'crmdb', TABNAME => 'T_ORDER_DELIVERY', CASCADE => TRUE); END;

*
ERROR at line 1:
ORA-20005: object statistics are locked (stattype = ALL)
ORA-06512: at "SYS.DBMS_STATS", line 24281
ORA-06512: at "SYS.DBMS_STATS", line 24332
ORA-06512: at line 1

确认出错信息:
SQL> select table_name,d.stattype_locked,D.LAST_ANALYZED,d.NUM_ROWS from user_tab_statistics d where table_name in ('T_ORDER_DELIVERY');

TABLE_NAME STATTYPE_LOCKED LAST_ANALYZED NUM_ROWS


T_ORDER_DELIVERY ALL 27-APR-2017 22:00:12 0

SQL> select count(*) from T_ORDER_DELIVERY;

COUNT(*)

1029883

说明该表的统计信息不准确,且自2017年以来都没有收集过;
解决方案:
1)解锁单个表对象:
查出schema下所有被锁定的表:
select table_name from user_tab_statistics where stattype_locked is not null;
查询单个表:
SELECT TABLE_NAME,D.STATTYPE_LOCKED,D.LAST_ANALYZED,D.NUM_ROWS FROM USER_TAB_STATISTICS D WHERE TABLE_NAME IN ('T_ORDER_DELIVERY');
然后解锁对象:
exec dbms_stats.unlock_table_stats('username','table_name');

SQL> exec dbms_stats.unlock_table_stats('crmdb','T_ORDER_DELIVERY');

PL/SQL procedure successfully completed.

再次收集统计信息:
SQL> exec DBMS_STATS.GATHER_TABLE_STATS(OWNNAME => 'crmdb', TABNAME => 'T_ORDER_DELIVERY', CASCADE => TRUE);

PL/SQL procedure successfully completed.

SQL> select table_name,d.stattype_locked,D.LAST_ANALYZED,d.NUM_ROWS from user_tab_statistics d where table_name in ('T_ORDER_DELIVERY');

TABLE_NAME STATTYPE_LOCKED LAST_ANALYZED NUM_ROWS


T_DM_ORDER_DELIVERY 22-JAN-2019 11:07:05 1029884

解锁整个schema:
DBMS_STATS.UNLOCK_SCHEMA_STATS('username');

那么为什么这些表的统计信息会被锁定呢?
有可能是为了稳定执行计划,或者是impdp只导入metadata_only导致,或者是人为手动锁定等。正常在Oracle10g及以上,Oracle默认会根据需要自动收集统计信息,如果想要想手动锁住统计信息,
可以使用DBMS_STATS.LOCK_SCHEMA_STATS和DBMS_STATS.LOCK_TABLE_STATS包进行锁定。

相关内容

热门资讯

今日重大通报“麻辣竞技有挂吗?... 网上科普关于“麻辣竞技有没有挂”话题很是火热,小编也是针对麻辣竞技作*弊开挂的方法以及开挂对应的知识...
重磅消息“鸿运会十三张开挂神器... 家人们!今天小编来为大家解答鸿运会十三张透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
最新引进“樱花之盛炸/金/花开... 最新引进“樱花之盛炸/金/花开挂器?”(必胜开挂神器)您好,樱花之盛炸/金/花这个游戏其实有挂的,确...
最新引进“卡农牛牛开挂器?”(... 家人们!今天小编来为大家解答卡农牛牛透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很...
玩家分享攻略“二八杠怎么开挂?... 有 亲,根据资深记者爆料二八杠是可以开挂的,确实有挂(咨询软件无需打开直...
【第一财经】“欢乐斗地主怎么开... 【第一财经】“欢乐斗地主怎么开挂?”(太坑了原来有挂)您好,欢乐斗地主这个游戏其实有挂的,确实是有挂...
重磅消息“黑桃A是不是有挂?”... 有 亲,根据资深记者爆料黑桃A是可以开挂的,确实有挂(咨询软件无需打开直...
【第一消息】“来趣广西麻将到底... 家人们!今天小编来为大家解答来趣广西麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里...
玩家最新攻略“星悦麻将怎么开挂... 玩家最新攻略“星悦麻将怎么开挂?”(必胜开挂神器)您好,星悦麻将这个游戏其实有挂的,确实是有挂的,需...
【第一消息】“福麻圈到底是不是... 您好:福麻圈这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏中...