首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql uuid去除

基础概念

UUID(Universally Unique Identifier)是一种软件建构的标准,亦为开放软件基金会组织在分布式计算环境领域的一部分。其目的是让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。

MySQL中的UUID类型用于存储一个128位的值,通常用来表示一个唯一的标识符。

相关优势

  1. 全局唯一性:UUID是由随机数或伪随机数生成的,因此几乎可以保证在任何地方都是唯一的。
  2. 易于生成:UUID的生成不需要中央服务器或协调器,可以在任何设备上独立生成。
  3. 版本多样性:UUID有多个版本,可以根据不同的需求选择合适的版本。

类型

MySQL中的UUID类型实际上存储的是一个36字符长度的字符串(包括4个连字符),但内部是以二进制形式存储的,占用16字节。

应用场景

  1. 数据库主键:UUID可以作为数据库表的主键,确保每个记录都有唯一的标识符。
  2. 分布式系统:在分布式系统中,UUID可以用来标识不同的节点或服务实例。
  3. 会话标识:在Web应用中,UUID可以用来生成会话ID,确保每个会话的唯一性。

去除UUID中的连字符

如果你想要去除UUID中的连字符,可以使用MySQL的内置函数REPLACE()REGEXP_REPLACE()

示例代码

假设你有一个名为users的表,其中有一个UUID类型的列id,你可以使用以下SQL语句去除连字符:

代码语言:txt
复制
UPDATE users SET id = REPLACE(id, '-', '');

或者使用REGEXP_REPLACE()(MySQL 8.0及以上版本):

代码语言:txt
复制
UPDATE users SET id = REGEXP_REPLACE(id, '-', '');

原因与解决方法

原因:UUID中的连字符是为了提高可读性而添加的,但在某些情况下,你可能不需要这些连字符,或者需要将它们去除以便与其他系统兼容。

解决方法:使用上述的REPLACE()REGEXP_REPLACE()函数可以轻松去除UUID中的连字符。

参考链接

请注意,在去除UUID中的连字符后,虽然仍然可以保证其唯一性,但可能会影响到某些依赖于UUID格式的系统或工具。因此,在执行此类操作之前,请务必确认这样做不会对你的应用造成负面影响。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

mysql java uuid_Java生成UUIDMySQL数据库如何生成uuid数据

UUID 来作为数据库数据表主键是非常不错的选择,保证每次生成的UUID 是唯一的。 UUID的唯一缺陷在于生成的结果串会比较长。...a.生成 UUID public static voidmain(String[] args) {for(int i=0;i<10;i++){ String uuid= UUID.randomUUID...* @return String UUID*/ public staticString getUUID(){ String uuid=UUID.randomUUID().toString();//...去掉“-”符号 return uuid.replaceAll(“-“, “”); } 二、MySQL数据库如何批量插入不重复uuid数据 第一步:先把需要查询的数据列出来select UUID(), a.Code...生成UUID /*只能生成一条*/SELECT REPLACE(UUID(),’-‘,”) AS id;/*在数据库中找一张数据多的表执行生成多条*/SELECT (REPLACE(UUID(),’-‘

4.7K30
  • MySQL中存储UUID的最佳实践

    MySQL中有一个UUID () 函数,通常用UUID做唯一标识,需要在数据库中进行存储。使用此函数可以让MySQL生成一个UUID值,并以VARCHAR(36)类型的可读形式返回。...但是对于像MySQL的InnoDB存储引擎来说,使用UUID作为主键(PRIMARY KEY)会带来一些问题。 1、问题阐述 问题一:UUID的长度问题 UUID的长度为36个字符。...如果这样的UUID作为主键的话,不仅会是主键的尺寸很大,而且会使二级索引的尺寸变大,原因是MySQL中的二级索引的value存的是PRIMARY KEY。...由于主键和二级索引的尺寸很大,所以不利于在内存中操作 问题二:UUID的格式问题 MySQLUUID ()使用的是version 1的UUID,该类型的UUID的特点是基于时间,它是一个128位的数字...那么我们可以使用虚拟列(MySQL5.7的新特性,虚拟列不占用存储空间)来存放文本形式的UUID。 然后,还有如何巧妙地重新排列二进制形式的字节的问题。

    9K30

    Mysql 8.0 更好的支持了 UUID

    定义了5个版本,MySQL 实现的是版本1,由 时间戳、UUID版本、MAC地址构成 好处 MySQL 中使用 UUID 是对 AUTO_INCREMENT PRIMARY KEY的一个很好的替代,有如下好处...keys 在不同 表、库、服务器 中都是唯一的 安全性更好,很难猜 可以离线生成 可以简化数据库复制 不足 但也有不好的地方: 增加了存储空间 增加了问题调试的难度 有性能问题,因为长度更长,并且无序 MySQL...8.0 的处理方法 MySQL8.0 新增了3个函数: UUID_TO_BIN BIN_TO_UUID IS_UUID 通过这3个函数,使我们可以更方便的应用UUID,并且是对上面提到的几点不足的一个解决方案...UUID_TO_BIN 用于对 UUID 字符串进行二进制压缩,32字符-->16bit BIN_TO_UUID 是相应的解压操作,16bit-->32字符 用法示例: 建表 CREATE TABLE...t (id binary(16) PRIMARY KEY); 插入 INSERT INTO t VALUES(UUID_TO_BIN(UUID())); 查询 SELECT BIN_TO_UUID(

    5.1K110

    为啥不能用uuidMySQL的主键 ?

    mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一,单机递增),而是推荐连续自增的主键id,官方的推荐是auto_increment,...那么为什么不建议采用uuid,使用uuid究竟有什么坏处?...本篇博客的目录 mysql程序实例 使用uuid和自增id的索引结构对比 总结 一、mysql和程序实例 1.1.要说明这个问题,我们首先来建立三张表 分别是user_auto_key,user_uuid...时间占用量总体可以打出的效率排名为:auto_key>random_key>uuid,uuid的效率最低,在数据量较大的情况下,效率直线下滑。那么为什么会出现这样的现象呢?...在实际的开发中还是根据mysql的官方推荐最好使用自增id,mysql博大精深,内部还有很多值得优化的点需要我们学习。

    3.9K20

    MySQL数据迁移批量写UUID数据工作记录

    MySQL数据迁移批量写UUID数据工作记录 背景:最近在迁移表数据,需要向一张业务关联表批量写数据,所以需要批量生成uuid和时间等等数据 软件环境: Mysql5.0+ navicat 注意:遇到一个问题...replace(uuid() , '-' ,''),通过replace查询uuid,发现全都一样,所以批量写数据时候,不能使用replace,直接使用uuid()这个函数就可以批量生成uuid,然后再更新...uuid就行 使用uuid()才会生成不一样的uuid insert into t_catalog_division (CODE, CREATE_MAN, CREATE_MAN_NAME, CREATE_TIME...,UPDATE_MAN,UPDATE_MAN_NAME,UPDATE_TIME,valid,FROM_CATALOG_CODE,BUSINESS_DIVISION_CODE) SELECT UUID()...(select FORM_CATALOG_CODE from t_catalog_division where FORM_CATALOG_CODE = a.CODE) limit 100 批量更新主键uuid

    1.4K20

    UUID 简介

    UUID版本 (Version 2) DCE 安全的 UUID 分布式计算环境(Distributed Computing Environment) 安全的 UUID 和基于时间的 UUID 算法相同,...这个版本的UUID在实际中较少用到。 UUID版本 (Version 3) 基于名字的 UUID(MD5) 基于名字的 UUID 通过计算名字和命名空间的 MD5 散列值得到。...这个版本的 UUID 保证了: 相同命名空间中不同名字生成的 UUID 的唯一性; 不同命名空间中的 UUID 的唯一性; 相同命名空间中相同名字的 UUID 重复生成是相同的。...UUID版本 (Version 4) 随机 UUID 根据随机数,或者伪随机数生成 UUID。 这种UUID产生重复的概率是可以计算出来的。...$uuid; } $uuid = "select uuid() as uuid"; echo create_v1uuid(); echo "uuid-v1: " . mysqli_fetch_assoc

    53110

    UUID 介绍

    在版本1的UUID中,这部分包含了表示时间的信息。时钟序列和随机数部分(16 bits): UUID中的一部分用于保证在同一时刻生成的UUID的唯一性。...例如,版本4的UUID中这一部分的值是0100。节点部分(48 bits): 在版本1的UUID中,这部分包含生成UUID的计算机的唯一标识。...变体标识和版本号部分: 这两部分标识了UUID的类型和变体。版本号标识了UUID的版本,而变体标识了UUID的变体(通常为标准的DCE UUID)。...节点部分: 在版本1的UUID中,这部分包含生成UUID的计算机的唯一标识。这有助于确保即使在不同的计算机上生成UUID,也不太可能发生冲突。...时钟回拨问题: 在版本1的UUID中,如果系统时钟发生回拨,可能导致生成的UUID不是严格递增的。这是因为UUID中包含了时间戳信息。4. 使用场景UUID 由于其唯一性和分散性,被广泛用于多种场景。

    1.5K20

    为什么MySQL不推荐使用uuid作为主键?

    前言 在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一,单机递增),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用...uuid,使用uuid究竟有什么坏处?...关注公种浩:程序员追风,回复012获取一套500多页PDF总结的MySQL学习笔记。...关于MySQL的知识点总结了一个思维导图分享给大家 [1240] 一、mysql和程序实例 1.1.要说明这个问题,我们首先来建立三张表 分别是user_auto_key,user_uuid,user_random_key...在实际的开发中还是根据mysql的官方推荐最好使用自增id,mysql博大精深,内部还有很多值得优化的点需要我们学习。

    4.9K30

    java中使用uuid函数_uuid主键

    由以下几部分的组合:当前日期和时间(UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同),时钟序列,全局唯一的IEEE机器识别号(如果有网卡...它们两的优缺点详细可网上进行查阅 java中的类java.Util.UUID (最好就是在java程序中生成UUID然后把数据插入到数据库,为了换数据库的话不用修改生成UUID的代码) jdk1.5增加了类...java.Util.UUID,用于方便生成UUID。...createUUID(){ String uuid=UUID.randomUUID().toString();return uuid.replace(“-“,””); } } 运行: 数据库中UUID...的存储类型 以mySql数据库为例 select replace(uuid(),’-‘,”) from dual; 运行: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

    2.5K30
    领券