我有一张像
f1|f2|fk
1 | 0|100
1 | 1|200
1 | 2|300
1 | 3|400
2 | 0|300
2 | 1|400
2 | 2|500
PK在哪里(f1,f2)
,fk是外键。fk 的值并不多,大约为 20。f2 永远不会超过 3。(f1,f2)
但是有很多对。(f1,fk)
是UNIQUE
。
现在,假设我们将 100 和 200 映射到 A,将 300 和 400 映射到 B,将 500 映射到 C——这个映射是给定的。我们想(f1_new,fk_mapped)
留下来UNIQUE
。到目前为止,这大致解决了
INSERT INTO mapped (f1_new,f2_new,fk_new)
SELECT f1, MIN(f2), CASE fk WHEN 100 THEN A WHEN 200 THEN A END AS fk
FROM origin
GROUP BY f1, fk
现在,问题是我们需要在映射表中保留 f2 值 0、1、2,所以这是期望的结果:
f1_new|f2_new|fk_mapped
1 | 0 |A
1 | 1 |B
2 | 0 |B
2 | 1 |C
我真的很想把它保留在 MySQL 中。