关于Rack()自增长的一则双表关联更新

A表(tb_abc):

创新互联长期为近1000家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为包河企业提供专业的成都做网站、成都网站制作,包河网站改版等技术服务。拥有10多年丰富建站经验和众多成功案例,为您定制开发。


AB
1aa
0200
2bb0300
3cc0500
4dd1800
5ee2200
6ff3300

B表(tb_abcc):


A
B
1aa
(0201)
2aa(0202)
3bb(0301)
4bb(0302)
5bb(0303)
6cc(0501)

括号里是预期值

规则: 通过B表的a字段匹配A表的a字段,并读取A表的b字段,按照该值依次增数写入B表b字段

实现:

update
  tb_abcc c
set
  c.b =
  (select
    tmp.str
  from
    (select
      b.rowid rd,
      b.a,
      substr(a.b, 1, 2) || lpad(
        (
          rank () over (partition by b.a
            order by b.rowid)
        ),
        2,
        0
      ) str
    from
      tb_abc a,
      tb_abcc b
    where a.a = b.a) tmp
  where c.rowid = tmp.rd)
where exists
  (select
    'x'
  from
    (select
      b.rowid rd,
      b.a,
      substr(a.b, 1, 2) || lpad(
        (
          rank () over (partition by b.a
            order by b.rowid)
        ),
        2,
        0
      ) str
    from
      tb_abc a,
      tb_abcc b
    where a.a = b.a) tmp
  where c.rowid = tmp.rd);

6 rows updated

select * from tb_abcc;

A    B

---- ------

aa   0201

aa   0202

bb   0301

bb   0302

bb   0303

cc   0501

6 rows selected

网站标题:关于Rack()自增长的一则双表关联更新
URL链接:https://www.cdcxhl.com/article8/ispoop.html

成都网站建设公司_创新互联,为您提供关键词优化软件开发App设计网页设计公司标签优化电子商务

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网站建设公司