V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
furtherRoad
V2EX  ›  问与答

求问:多表 sql 并发生成唯一列数值列

  •  
  •   furtherRoad · 57 天前 · 678 次点击
    这是一个创建于 57 天前的主题,其中的信息可能已经有所发展或是发生改变。

    将 oracle 中的 5 个表同步到 mysql 的 1 个表中; mysql 中需要有一个新增字段(pkm)为 bigint 类型; 这 5 个 oracle 表的数据和数据量会实时变化; 无法改变目标数据源 mysql 的表结构; 现在需要使用 oracle 的 select 语句生成一列新的列,方便抽取到 mysql ; 需要生成的列(pkm)必须是唯一值,不能和其他表重复; 每个 select 是并发执行,不是逐个执行。

    所以用 ROW_NUMBER()不太合适,如: SELECT

    ROW_NUMBER() OVER (ORDER BY id) +

    (SELECT COUNT(*) FROM table1) +

    ...+

    (SELECT COUNT(*) FROM table5)

    2 条回复    2024-09-14 11:42:07 +08:00
    xiaozirun
        1
    xiaozirun  
       57 天前
    浅见,pkm 列的值可以是:表序号+左补零后的表 id ,这样的话就可以保证 pkm 列的值唯一
    haah
        2
    haah  
       56 天前
    1. 雪花算法
    or
    2. uuid to bigint.
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1782 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 16:36 · PVG 00:36 · LAX 08:36 · JFK 11:36
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.