今天在生产上执行一个update,报出ORA-14402: updating partition key column would cause a partition change。原因是修改分区字段所引起的。
update schema.table_nameset time_a = time_bwhere code_a = xxxxxxxxxxxxxxxxand status = xxxand to_char(time_a, 'dd') != to_char(time_b, 'dd')and time_a > to_date('2010-06-01', 'yyyy-mm-dd');
1.仔细的看了看该表,是以time_a 为分区字段,5天一个分区。而update的语句中有将6号的时间改为5号的日期的情况。
2.然后查询一下生产的row movement策略
select table_name,owner,row_movement from dba_tables where table_name = 'table_name';
的确是disabled的状态
3.修改该策略
alter table schema.table_name enable row movement;
4.执行语句
5..修改回来
alter table schema.table_name disable row movement;
搞完收工
另:其实这个不是万全之策,如果偶尔的修改没有问题;如果要经常修改,则说明该表设计的不好,分区字段一般是不能用于修改的。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/11258275/viewspace-666497/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/11258275/viewspace-666497/