当前位置: 首页 > news >正文

数据库中数据的id生成和算法

id生成策略

自增主键

一般使用整数类型的id可使用自增主键的策略去生成id

优点:

  • 简单、易于使用和理解。
  • 保证唯一性,无需额外的查询操作。
  • 提高查询性能,因为ID是有序的,且支持索引。

缺点:

  • 不适用于分布式系统,因为每个节点都需要维护一个独立的计数器,可能会导致冲突和性能问题。
  • 暴露了表中的数据增长模式,可能导致信息泄漏和数据分析的问题。

使用方法:可使用Mybatis-Plus

UUID(Universally Unique Identifier)

优点:

  • 全局唯一性,可以在不同的数据库服务器上生成,确保全局唯一性。
  • 分布式支持,独立性。

缺点:

  • 占用较多的存储空间,因为UUID是一个128位的数字,通常以32位的十六进制数表示。
  • 无序性,可读性较低。

适用场景:适用于需要分布式支持、全局唯一性和独立生成ID的场景,特别是在没有数据库连接的情况下。

使用方法:可使用Hutool工具中的IdUtil生成

组合ID

原理:根据多个字段的组合来生成唯一的ID。通常使用字段的值进行哈希运算,以生成一个唯一的标识符。

优点:可以根据业务逻辑自定义ID生成规则。

缺点:需要确保组合字段的唯一性,否则可能导致ID冲突。

适用场景:适用于需要根据多个字段组合来生成唯一ID的场景。

雪花算法(Snowflake)

原理:生成一个64位的long型数字作为全局唯一ID。它包含时间戳、工作机器ID、数据中心ID和序列号等部分。

优点:

  • 支持分布式环境,生成的ID有序且唯一。
  • 包含时间戳信息,可以用于排序。

缺点:

  • 依赖于机器的唯一标识,不同机器之间的时间同步问题可能导致ID重复。
  • 需要确保工作机器ID和数据中心ID的唯一性。

适用场景:适用于需要分布式支持、有序和唯一ID的大规模系统,如微服务架构、分布式数据库等。

获取id的问题

如果使用mybatis-plus框架时,当使用@TableId指定某个id的生成策略后,在将该数据插入数据库后,该id会自动保存在刚操作过的实体类中,可直接读取

http://www.lryc.cn/news/379453.html

相关文章:

  • SystemVerilog Assertion精华知识
  • pdf怎么压缩到2m以内或5m以内的方法
  • Butter Knife 8
  • AMSR/ADEOS-II L1A Raw Observation Counts V003地球表面和大气微波辐射的详细观测数据
  • MySQL之复制(十一)
  • 深入源码设计!Vue3.js核心API——Computed实现原理
  • 驾考小技巧:老北京布鞋!距离高考出分还剩3天,我却看到有些孩子已经拿了“满分”——早读(逆天打工人爬取热门微信文章解读)
  • java-正则表达式 2
  • hadoop常见简单基础面试题
  • 泄漏检测(LDAR)在建档和检测过程中造假套路和不规范行为
  • Android CTS环境搭建
  • 比较Zig、Rust和C++
  • 路由的params参数,命名路由,路由的params参数,命名路由
  • java:CompletableFuture的简单例子
  • element的table获取当前表格行
  • html做一个分组散点图图的软件
  • 【SQL】UNION 与 UNION ALL 的区别
  • 分类判决界面---W-H、H-K算法
  • Python基础教程(三十):math模块
  • 你只是重新发现了一些东西
  • 【英伟达GPU的挑战者】Groq—AI大模型推理的革命者
  • Python学习路线
  • C++ std::forward()
  • 常见的8种排序(含代码):插入排序、冒泡排序、希尔排序、快速排序、简单选择排序、归并排序、堆排序、基数排序
  • go语言day2
  • vue echarts画多柱状图+多折线图
  • cesium for unity 打包webgl失败,提示不支持
  • python开发基础——day7 序列类型方法
  • 用java写一个二叉树翻转
  • 数学建模系列(3/4):典型建模方法