首页-玉祥公司客服

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 2255|回复: 2
打印 上一主题 下一主题

[分享] oracle中自动编码

[复制链接]

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
跳转到指定楼层
楼主
发表于 2020-2-21 19:59:22 | 显示全部楼层 |只看大图 回帖奖励 |倒序浏览 |阅读模式
现有如下图所示一张表:

最终要实现下面这样的编码结果:
  1. --要求最终的结果,自动编码
  2. ID p_id NAME CODE
  3. 1 1 -1  A   03
  4. 2 2 1   B1  0301
  5. 3 5 2   C1  030101
  6. 4 6 2   C2  030102
  7. 5 3 1   B2  0302
  8. 6 7 3   D1  030201
  9. 7 4 1   B3  0303
复制代码


实现代码如下:
  1. select id,
  2.        p_id,
  3.        name,
  4.        decode(p_id,
  5.               -1,
  6.               code,
  7.               code ||
  8.               replace(substr(sys_connect_by_path(pos, '.'),
  9.                              instr(sys_connect_by_path(pos, '.'), '.', 1, 2)),
  10.                       '.',
  11.                       '0')) new_code
  12.   from (select id,
  13.                p_id,
  14.                name,
  15.                last_value(code ignore nulls) over(order by rownum) code,
  16.                row_number() over(partition by p_id order by rownum) pos
  17.           from t_test)
  18. start with p_id = -1
  19. connect by prior id = p_id;
复制代码


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
沙发
 楼主| 发表于 2020-2-22 12:54:41 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

手机版|小黑屋|首页-玉祥公司客服  本站关键词:玉祥平台客服

GMT+8, 2024-6-17 14:21 , Processed in 0.125179 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表