mysql数据库有没有类似于SQLserver中的guid编号自己生成不重复?怎么用
4条回答 默认 最新
- 那小麦 2019-03-05 16:48关注
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了。
2019年家电行业分析报告www.danews.cc/tech/2019/0305/2627.html本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵