oracle 复制行记录,Oracle复制行记录的小技巧

博客探讨了在数据库中复制和更新记录的两种方法:通过循环遍历并修改插入,以及使用游标处理。这两种方案主要用于当需要复制一条记录但仅改变一两个字段的情况。示例代码展示了如何在PL/SQL中实现这一操作,同时也提到查询和插入的表可以不同。寻求更高效或简便的解决方案。
摘要由CSDN通过智能技术生成

需求:

对于数据库的某些表,我们常要复制其对应的某条记录,新纪录与老记录仅有某一两个字段值不一样,其他完全一样。寻找简单的方案,而不是逐个字段拼Sql。

解决方案1:

begin

for rs in (select * from dept where deptno=40)

loop

rs.deptno:=50;

insert into dept values rs;

end loop;

end;

/

解决方案2:

declare

cursor dept_cursor is select * from dept where deptno=40;

begin

for dept_rs in dept_cursor

loop

exit when dept_cursor%notFound;

dept_rs.deptno:=null;

insert into dept values dept_rs;

end loop;

end;

/

备注:

查询的 表名 与插入的 表名 可以不一样,例如,查询:descartes,插入descartes_history

若有更好方法,请指教。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值