zoukankan      html  css  js  c++  java
  • 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  这哥们用存储过程,倒也可以。权当参考了。

  • 相关阅读:
    选择语句(if else) 习题(2017/12/1)
    Java代码空格问题
    设置背景图片
    寄存器
    8086微处理器的组成和工作原理
    8086引脚
    换行的训练
    彩票 双色球 36选7
    函数
    字符串
  • 原文地址:https://www.cnblogs.com/tibit/p/6183864.html
Copyright © 2011-2022 走看看