zoukankan      html  css  js  c++  java
  • Oracle应用之批量递增更新数据脚本

    需求:更新用户表的工号,格式为“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;
    
  • 相关阅读:
    puppet master/agent
    puppet单机模型
    Nginx MogileFS 配置
    mogilefs 安装与配置
    CMakeLists.txt
    下载安装MariaDB Galera 10.1
    BZOJ1295: [SCOI2009]最长距离
    BZOJ2375: 疯狂的涂色
    BZOJ1260: [CQOI2007]涂色paint
    BZOJ2789: [Poi2012]Letters
  • 原文地址:https://www.cnblogs.com/mzq123/p/12910052.html
Copyright © 2011-2022 走看看