当前位置:   article > 正文

Oracle数据库错误码1502解决,SQL的1502错误处理

ora-1502

有关错误的中文意

[Error Code: 1502, SQL State: 72000] ORA-01502: 索引

'UserXXX.XPKTAB_NAME' 或这类索引的分区处于不可用状态。

对错误的处理

alter index UserXXX.XPKTAB_NAME rebuild

错误原因

出现高水位(High Water

Mark),对数据库中的表进行信息插入时,该水位线会增加,但在进行Delete操作时,水位线不会发生变化。

也就是说,这条高水位线在日常的增删操作中只会上涨,不会下跌。

select时是对HWM所标注的范围内进行扫描。

所以有时候有人总是经常说,怎么我的表中没有几条数据,但是还是这么慢呢,这个时候其实奥秘就是这里的高水位线了。

所以如果需要把表清空,在有可能利用TRUNCATE语句来删除数据的时候就利用TRUNCATE语句来删除表,特别是那种数据量有可能很大的临时存储表。

修正ORACLE表的高水位线

在ORACLE中,执行对表的删除操作不会降低该表的高水位线。而全表扫描将始终读取一个段(extent)中所有低于高水位线标记的块。如果在执行删除操作后不降低高水位线标记,则将导致查询语句的性能低下。下面的方法都可以降低高水位线标记。

1.执行表重建指令 alter table table_name move;(在线转移表空间ALTER TABLE 。。。

MOVE TABLESPACE 。。。ALTER TABLE 。。。 MOVE

后面不跟参数也行,不跟参数表还是在原来的表空间,move后记住重建索引。如果以后还要继续向这个表增加数据,没有必要move,只是释放出来的空间,只能这个表用,其他的表或者segment无法使用该空间)

2.执行alter table table_name shrink space; 注意,此命令为Oracle

10g新增功能,再执行该指令之前必须允许行移动alter table table_name enable row

movement;

3.复制要保留的数据到临时表t,drop原表,然后rename临时表t为原表

4.emp/imp

5.alter

table  table_name

deallocate

unused

6.尽量truncate吧

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/614255
推荐阅读
相关标签
  

闽ICP备14008679号