MySql中利用insert into select 准备数据uuid主键冲突

来源:互联网 发布:防sql注入最佳 编辑:程序博客网 时间:2024/05/16 08:34

转载:
http://www.cnblogs.com/tibit/p/6183864.html

MYSQL 中表1需要准备大量数据,内容主要取自表2,id必须为32位uuid (项目所有表都是这样,没办法), 准备这样插入:

INSERT INTO TBL_ONE (ID, SOID, SNAME) SELECT    REPLACE (UUID(), '-', ''),    TWO.ID,    TWO.NAMEFROM    TBL_TWO TWO

报错: Duplicate entry ‘4534c15dc2a111e6a9ab000ec6c596eb’ for key ‘PRIMARY’,显然主键冲突了, REPLACE (UUID(), ‘-‘, ”) 仅执行了一次,

找了半天,似乎也没有最简单的解决方案。退而求其次,我想到的最简单解决方案:

INSERT INTO TBL_ONE (ID, SOID, SNAME) SELECT    UUID(), #UUID()为什么可以?    TWO.ID,    TWO. NAMEFROM    TBL_TWO TWO;8 UPDATE TBL_ONE SET ID = REPLACE (ID, '-', '');

uuid()生成的id不会重复,但是会有”-“,用空格替换一下就ok了。

原创粉丝点击