感谢各位回复
1
yulitian888 2020-12-27 13:39:14 +08:00
上策:另立新 ID,好像并不需要什么特别的工具哦!
中策:给每个不同的源库加上不同的前缀数字,比如 A 库来的叫做 32000xxxx,B 库来的叫做 98000xxxx,补以适当的补位数即可。好像,也不需要什么特别的工具哦! 下策:发个问题,坐等别人介绍工具 |
2
roundgis 2020-12-27 13:40:39 +08:00 via Android
如果沒有 unique index
你如何判斷該記錄是不是相同的呢 |
3
encro 2020-12-27 13:42:38 +08:00
没有,如果做了表关联的话。
|
4
wuwukai007 OP @yulitian888 表太多了,几百张表,数据量也比较大,好几台服务器,自己弄估计费劲!
|
5
buhi 2020-12-27 13:49:26 +08:00
不合并不就完事了, 首先合并是图啥
|
6
wuwukai007 OP @roundgis 有一个类似产品 ID 的 字段,和创建时间可以锁定唯一,
|
7
notejava 2020-12-27 14:03:38 +08:00
重新生成分布式 ID,再将相关联表的 ID 离线重新绑定。
|
8
xiaofan2 2020-12-27 14:04:59 +08:00 2
大家都是数据量太大了做拆分 你这反而给他合并起来了 这就是传说中的分久必合?
|
9
wuwukai007 OP @xiaofan2 上面要求,硬着头皮干呗。
|
10
loading 2020-12-27 14:19:54 +08:00 via Android
前面加一位不就好了
例如 100000 数 012345 200000 字 012345 |
11
yulitian888 2020-12-27 15:07:49 +08:00
@wuwukai007 不管多少张表,在不借助其它工具的情况下,操作基本只考虑一种 sql 句式了
insert into 目标表 select 字段 1,字段 2... from 源表 然后,加一个变量进去很复杂? insert into 目标表 select 前缀+字段 1,字段 2... from 源表 表再多也不过就是把前缀做成变量而已。用工具不是一样道理吗,将一个如上查询结果集作为导出范围,一模一样啊 |
12
wangsongyan 2020-12-27 15:20:09 +08:00 via iPhone
自己写工具,合并表时生成新的 id 同时更新关联 id 。话说之前帮别人写了个工具,工具写完人联系不上了😂
|
13
opengps 2020-12-27 15:27:47 +08:00 1
你们最初拆分的时候就不合理,应当用不一样的起始种子和步长,现在要合并,就直接按照库做分段吧,比如 A 库占用 1-100000,B 库占用 10001-20000,这样来融合
|
14
alonehat 2020-12-27 16:00:41 +08:00
是都从 1 开始自增的?有关联关系吗,没有的话直接数据库对拷或者写个批量插入工具不插 ID 继续自增就是了;有关联关系的话那考虑到关联也只能新加几个个字段区分,改成组合外键
|
15
mmdsun 2020-12-27 17:05:43 +08:00 via Android
批量 insert 不插入 ID 字段不就可以了么。
难道说表关联也是用的自增 ID ? |
16
elintwenty 2020-12-27 20:22:07 +08:00
这个问题难道不是先要看有没有关联的情况吗?没有关联就随意处理了
|
17
fox0001 2020-12-27 23:23:52 +08:00 via Android
建立新库,新增两个字段:
1 )新建新的主键字段,标记数据唯一。 2 )新建机器编号字段,标记数据来自哪个机器。 这样,涉及关联的话,就用旧 ID 与机器编号去关联现有数据 |
18
mingl0280 2020-12-27 23:43:07 +08:00
并库不并表,表加前缀。
|
19
we3613040 2020-12-28 07:31:49 +08:00
连表都合并了?那当初为啥要拆。。。。。
|
20
nano91 2020-12-28 08:57:29 +08:00
@wuwukai007 你有没有考虑过这么大的数据量合并完了以后,你的服务还有可用性吗?
|
21
wangritian 2020-12-28 09:20:10 +08:00
上面要求?兄弟这种不合理的要求一定要据理力争啊,到时候查询扛不住再分库分表你不是白干了
|
22
wuwukai007 OP @nano91 @wangritian 之前是分库+ 分表,发现 分表就可以满足了,现在调整成 把多个库 合并,在分表。
|
23
prodcd 2020-12-28 16:44:26 +08:00
新建一个表,使用新的自增 id,增加 2 个字段,old_server 、old_id 备用,等啥事都没有了可以考虑删掉
不过你这需求真奇葩。 |