MySql中利用insert into select 准備數據uuid主鍵沖突


 

MYSQL 中表1需要准備大量數據,內容主要取自表2,id必須為32位uuid (項目所有表都是這樣,沒辦法), 准備這樣插入:

1 INSERT INTO TBL_ONE (ID, SOID, SNAME) SELECT
2     REPLACE (UUID(), '-', ''),
3     TWO.ID,
4     TWO.NAME
5 FROM
6     TBL_TWO TWO

報錯: Duplicate entry '4534c15dc2a111e6a9ab000ec6c596eb' for key 'PRIMARY',顯然主鍵沖突了, REPLACE (UUID(), '-', '') 僅執行了一次,

找了半天,似乎也沒有最簡單的解決方案。退而求其次,我想到的最簡單解決方案:

1 INSERT INTO TBL_ONE (ID, SOID, SNAME) SELECT
2     UUID(), #UUID()為什么可以?
3     TWO.ID,
4     TWO. NAME
5 FROM
6     TBL_TWO TWO;
7 8 UPDATE TBL_ONE SET ID = REPLACE (ID, '-', '');

uuid()生成的id不會重復,但是會有"-",用空格替換一下就ok了。

http://bijian1013.iteye.com/blog/2306590  這哥們用存儲過程,倒也可以。權當參考了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM