oracle 批量更新脚本,Oracle应用之批量递增更新数据脚本

5268f80b9b1e01f982625ef6fac83ca1.png

需求:更新用户表的工号,格式为“GD1,GD2,...”的格式,如果有数据取最大值再递增

E1:先查询出是否有数据,有数据取最大值再递增,使用nvl函数

/* 查询max值*/

select nvl(max(to_number(replace(t.user_num, ‘GD‘, ‘‘))), 0)

from t_user t

where t.user_num like ‘GD%‘;

E2:创建Oracle序列,start with改为max值

/* Create sequence,start with改为max值 */

create sequence user_num_t_user

minvalue 1

maxvalue 999999999999999999999999999

start with 200

increment by 1

cache 20;

commit;

/* drop sequence */

drop sequence user_num_t_user;

E3:批量更新

/* batch update*/

update t_user

set user_num = ‘GD‘ || user_num_t_user.nextval

where user_num is null

and IS_OUTNET_REG = 0;

E4:如果下次使用序列,记得更改start with的值,因为每次使用都会更新这个值的

上面方法是使用Oracle序列的方法,如果用Oracle的rownum,也是可以实现需求的,脚本如:

update t_user

set user_num = ‘GD‘ ||

(rownum +

(select nvl(max(to_number(replace(t.user_num, ‘GD‘, ‘‘))),

0)

from base_user t

where t.user_num like ‘GD%‘))

where user_num is null;

Oracle应用之批量递增更新数据脚本

标签:函数   batch   批量更新   ber   数据   ace   用户表   com   ora

1428d0e076c3959ab11d28a39bc84fab.png

5268f80b9b1e01f982625ef6fac83ca1.png

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:https://www.cnblogs.com/mzq123/p/12910052.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值