雪花算法

目录

一、什么是雪花算法

二、使用雪花算法

​三、使用UUID


使用自增主键是数据库中常用的唯一标识,今天尝试使用mybatisplus来实现三种方式的主键ID

使用起来也很简单 用注解指定一下使用那种方式的主键

一、什么是雪花算法

一种特殊的算法可以计算得到一个唯一标识

二、使用雪花算法

java 复制代码
     /**
     * 数据库ID自增
     * <p>该类型请确保数据库设置了 ID自增 否则无效</p>
     */
    AUTO(0),
     /* 以下2种类型、只有当插入对象ID 为空,才自动填充。 */
    /**
     * 分配ID (主键类型为number或string),
     * 默认实现类 {@link             com.baomidou.mybatisplus.core.incrementer.DefaultIdentifierGenerator}(雪花算法)
     *
     * @since 3.3.0
     */
    ASSIGN_ID(3),
    /**
     * 分配UUID (主键类型为 string)
     * 默认实现类 {@link     com.baomidou.mybatisplus.core.incrementer.DefaultIdentifierGenerator}(UUID.replace("-",""))
     */
    ASSIGN_UUID(4);
java 复制代码
 @RequestMapping("/test")
    void test() {
        //目前这个id是没有填充的
        SysUser sysUser = new SysUser();
        sysUser.setUserAccount("153abc");
        sysUser.setUserPassword("h12345");
        sysUser.setCreateBy(67L);
        sysUser.setUpdateBy(99L);
        System.out.println("调用insert之前的id:" + sysUser.getUserId());
        sysUserService.insertUser(sysUser);
        //调用之后,数据不仅会保存到数据库,而且会自动更新当前对象的值
        System.out.println("调用insert之后的id:" + sysUser.getUserId());
    }

数据库表中也会多一条数据

三、使用UUID

修改注解中的参数

数据不仅更新到数据库了 也帮我们更新了当前这个对象中的数据

相关推荐
@大嘴巴子2 分钟前
MySQL知识回顾总结----数据库基础
数据库·mysql
lubiii_2 分钟前
SQL手工测试(MySQL数据库)
数据库·mysql·web安全·网络安全
魔镜魔镜_谁是世界上最漂亮的小仙女4 分钟前
java-集合
java·后端·程序员
真实的菜5 分钟前
消息队列高级特性与原理:解锁分布式系统的底层逻辑
java
若水不如远方7 分钟前
java范型
java
凌辰揽月9 分钟前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
想你依然心痛14 分钟前
数据库入门:从原理到应用
数据库
lifallen15 分钟前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法
长安不见17 分钟前
背景知识: 理解LimitLatch背后的AQS
java
小吕学编程20 分钟前
策略模式实战:Spring中动态选择商品处理策略的实现
java·开发语言·设计模式