oracle数据库里存放着各种各样的数据,其中有一些数据表会随着时间的推移,越来越大.如交友聊天的日志. 短信收发的日志.生产系统的日志.动态网站发布系统的日志等等.这样的信息又与时间紧密相关,有没有办法 让这些日志表能到时间自动分割成历史年月(如log200308,log200309)的表呢? 请看看我用存储过程定期分割表的 方法吧.
1.初学数据库时只知道用delete来删除表里的数据.但在oracle数据库里,大量delete记录后,并不能释放表 【程序编程相关:3月9日Red Hat对initscri】一.问题的引出 【推荐阅读:3月9日Red Hat对squid升级】2.用重命名(rename)表的方法 【扩展信息:3月9日Red Hat对mailman升】所占用的物理空间,这里面有一个高水位的概念,所以我们不能用delete来分割表.(1).先建一个与原来日志表(假如是log)数据结构一模一样的新表(如log_new),建约束.索引及指定字段的默认值;(2).重命名表log到log_yyyymm; 要注意的问题是oltp系统可能会因为dml操作阻碍重命名执行成功,出现ora-00054资源正忙的错误提示,需要试多次才能成功.(3).重命名表log_new到log.这样应用程序不用修改(受影响的时间仅几秒钟),日志表就被截断分割了.上述步骤可以在oracle里可以用存储过程来实现它们.二.用存储过程来分割表可以看到在重命名表的方法中,步骤(2)是个关键.下面这个rename_table过程会在有锁阻碍的情况下用递归的方式重试100次.... 下一页