oracle 跟据前缀规则生成编码解决方法

    先说需求。
    人员属于组织机构,组织机构为11位字符串代码,人员代码需要在新增人员时后台生成。
    生成规则  人员代码 = 组织机构代码前7位+ 4位的数字。
    要求:1、生成的代码不可以重复(废话)
            2、可以找到最小的未使用的代码。如 跟据前缀【2130102】 
                  表中数据目前只有【2130102】【0002】 那应该得到 【2130102】【0001 】
                  如果表中数据有 【2130102】【0001】,【2130102】【0002】 那应该得到 【2130102】【0003】

    需求说明白了,直接上解决方法,一个sql语句搞定问题。

    

点击(此处)折叠或打开

  1. select '2130102' /*P_PREFIX*/||lpad(min(t.seq),4,'0')
  2. from (select rownum seq from dual connect by level <10000)t
  3. where t.seq not in (select to_number(jbgm,8,4))
  4. from t_pt_qx_zzjg t
  5. where t.jgbm like '2130102%'/*P_PREFIX*/

下面唠叨下关于这个语句性能相关的东西。
1、使用到 select rownum seq from dual connect by level  < 10000 来构造虚拟表,生成的表会放在内存中,所以数量不应太大 。一般来说10000的数量基本可以满足所有的需求了。
2、connect by level 3、一定要在将要生成编码的字段上建立索引,不然严重影响效率。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30066956/viewspace-1403733/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/30066956/viewspace-1403733/

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值