度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 2127|回复: 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空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

348

主题

3572

帖子

9741

积分

论坛元老

Rank: 8Rank: 8

积分
9741
沙发
发表于 2020-2-21 21:39:02 | 只看该作者
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
板凳
 楼主| 发表于 2020-2-22 12:54:41 | 只看该作者
回复 支持 反对

使用道具 举报

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

本版积分规则

手机版|小黑屋|玉祥公司客服-玉祥集团客服  本站关键词:快速开发平台

GMT+8, 2024-5-18 12:55 , Processed in 0.126863 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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