前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle应用之批量递增更新数据脚本

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

作者头像
SmileNicky
发布2020-05-18 22:57:57
8630
发布2020-05-18 22:57:57
举报
文章被收录于专栏:Nicky's blog

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

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

代码语言:javascript
复制
/* 查询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值

代码语言:javascript
复制
/* 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:批量更新

代码语言:javascript
复制
/* 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,也是可以实现需求的,脚本如:

代码语言:javascript
复制
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;
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/05/18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档