qq_43206157
qq_43206157
采纳率33.3%
2019-03-05 11:21 阅读 1.0k
已采纳

mysql数据库设置编号UUID怎么使用?

mysql数据库有没有类似于SQLserver中的guid编号自己生成不重复?怎么用

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

4条回答 默认 最新

  • 已采纳
    mz173117658 那小麦 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

    点赞 1 评论 复制链接分享
  • wojiushiwo945you 毕小宝 2019-03-05 13:40

    首先,MySQL提供了UUID函数实现uuid的生成。
    其次,除了主键自增的方式外,没有直接设置uuid生成主键的方法。
    详细参考:https://www.cnblogs.com/conanwang/p/5848006.html

    点赞 评论 复制链接分享
  • qq_32409957 可爱的小书包 2019-03-05 16:32

    mysql中提供了UUID()函数,具体使用可以直接写select UUID();进行测试.
    但是为了防止增长不重复,可以在建表的时候,使用auto_increment进行建表,比如

    create table temp(
        id int primary key auto_increment
    )
    

    或者是实在需要进行uuid的生成,可以使用如下的方式
    在插入值的时候,使用

    
    create table temp(
        id varchar primary key
    );
    insert temp(id) values(UUID());
    

    进行插入

    点赞 评论 复制链接分享
  • weixin_36876700 混沌太初 2019-03-05 19:03

    UUID在java中用代码生成,MYsql还不具备这个类型的字段,如果自己封装,还不如用java代码实现,你可以用Postgresql,功能超强大,绝对在mysql之上,支持类型超多

    点赞 评论 复制链接分享

相关推荐