分区表的数据修改深入

  需求案例:student表中储存学生的信息,按照班级进行了分区,一个学生转了班级,他的信息需要在student表中修改。


  student表结构语句

  create table student(id number(5),name varchar2(10),class_id number(2)) partition by list(class_id)(partition P_01        values (1),partition P_02 values (2));


  测试数据

  insert into student values(1,'xiaoming',1);

  insert into student values(2,'xiaohong',1);

  insert into student values(2,'xiaohua',2);

  insert into student values(2,'xiaoyue',2);

  commit;

  修改xiaoming的id=3,修改后,数据所在的分区没有改变。

  update student n set n.id=3 where n.name ='xiaoming'; 

  commit;

   

  修改xiaoming到班级2

  update student n set n.class_id=2 where n.name ='xiaoming';

  执行会报错

  

  原因分析:因为分区表的数据是按分区规则存入不同的分区,如果数据修改后,不在一个分区了,数据需要先删除,再插入新的分区,而数据库中对应的参数未设置,就导致了报错

  解决办法:

  1.导出需要修改的数据到临时表,再临时表中修改数据,删除原表需要修改的数据,把临时表的数据插入分区表中

   优势:对数据库不用修改参数,可以保证对系统的性能影响小

   劣势:数据量大的情况,高水位问题会较明显

   create table student_tmp as select * from student n where n.name ='xiaoming';

   update student_tmp n set n.class_id=2 where n.name ='xiaoming';

   commit;

   delete from  student n where n.name ='xiaoming';

   commit;

   insert into student  select * from student_tmp;

   commit;

   

   2.开启数据库 row movement

    优势:数据库可以对分区表进行跨分区修改

    劣势:由于是对数据库的参数进行修改,产生的影响较大,需要进行各方面的测试,已考虑对系统的影响降到最低

    alter table student enable row movement;

    执行了这条语句后,再对分区表进行跨分区修改数据就没有问题了

     update student n set n.class_id=2 where n.name ='xiaoming';

     commit;

     

     结语:实施操作都要根据实际情况,在对分区表的跨分区修改较频繁的情况,为了工作方便,可以开启row movement,但是需要进行监控数据库,保证数据库的稳定,这个在生产中是首要考虑,如果数据的修改较少,这种情况还是使用导出数据的方法吧,稳定是数据库运维的首条军规。

     

  

   

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31418864/viewspace-2284926/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31418864/viewspace-2284926/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值