ORACLE 修改分区表存储参数freelists后偶然性丢失数据

环境:

ORACLE 9.2.0.8,AIX 5.3ML5  64bit;

表A是个分区表,共存储大约2千万条记录;表所在的表空间未启用ASSM,为Manual 模式;

场景说明:

由于对该表的操作非常频繁,出现在该表上的I/O等待;为了增强并发性,修改表的存储参数:

alter table A storage (freelists 10 );

修改后,在系统高峰时期,对该表的Insert操作会出现数据丢失。客户端执行Insert语句并commit成功,但实际数据并没有保存到的数据库中。

系统的Alert.log中并无任务警告或错误。

将freelists参数改为1后,症状消失。

原因:

search 了meatlink,没有相关症状的记录。

现在还不清楚这个现象是客户端bug导致还是数据库bug导致,但将存储参数改回原值之后,系统的确不再丢失数据。

经验:

高并发表建议使用ASSM+Manual的tablespace;

建表后,建议不要修改存储参数;表的存储参数最好在建表时指定;

指定合适的freelists参数对频繁操作的表的性能优化非常明显;

转载于:https://www.cnblogs.com/sgsoft/archive/2011/03/21/1989865.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值