需求案例: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,但是需要进行监控数据库,保证数据库的稳定,这个在生产中是首要考虑,如果数据的修改较少,这种情况还是使用导出数据的方法吧,稳定是数据库运维的首条军规。
分区表的数据修改深入
来源:这里教程网
时间:2026-03-03 12:45:06
作者:
编辑推荐:
- 分区表的数据修改深入03-03
- word单行页边距调整的方法是什么03-03
- word2016文档图标显示不正常应该怎么解决03-03
- 怎么在word文档中添加漂亮的松树边框03-03
- word如何使用模板设计漂亮的奖状03-03
- 怎么在word文档中设置批量打印奖状03-03
- Word2016文档字符间距设置技巧是什么03-03
- 在word文档中应该如何加粗表格边框03-03
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- 分区表的数据修改深入
分区表的数据修改深入
26-03-03 - oracle性能调优-虚拟索引
oracle性能调优-虚拟索引
26-03-03 - Debian cd命令完全指南(新手也能轻松掌握Linux切换目录技巧)
Debian cd命令完全指南(新手也能轻松掌握Linux切换目录技巧)
26-03-03 - Oracle 脚本-线上哪些索引从来没有被使用过
Oracle 脚本-线上哪些索引从来没有被使用过
26-03-03 - 创建dblink的几种方法
创建dblink的几种方法
26-03-03 - 搭建集群数据库dbca时报错
搭建集群数据库dbca时报错
26-03-03 - linux6.5下安装oracle11g
linux6.5下安装oracle11g
26-03-03 - weblogic 软件安装
weblogic 软件安装
26-03-03 - Tuning Log Switches
Tuning Log Switches
26-03-03 - windows服务器下tns12560 适配器错误
windows服务器下tns12560 适配器错误
26-03-03
