雪花算法

目录

一、什么是雪花算法

二、使用雪花算法

​三、使用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

修改注解中的参数

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

相关推荐
喵手20 分钟前
如何利用Java的Stream API提高代码的简洁度和效率?
java·后端·java ee
-Xie-21 分钟前
Maven(二)
java·开发语言·maven
IT利刃出鞘34 分钟前
Java线程的6种状态和JVM状态打印
java·开发语言·jvm
薛晓刚38 分钟前
当MySQL的int不够用了
数据库
SelectDB技术团队1 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术
星空下的曙光1 小时前
mysql 命令语法操作篇 数据库约束有哪些 怎么使用
数据库·mysql
小楓12011 小时前
MySQL數據庫開發教學(一) 基本架構
数据库·后端·mysql
天天摸鱼的java工程师1 小时前
Java 解析 JSON 文件:八年老开发的实战总结(从业务到代码)
java·后端·面试
白仑色1 小时前
Spring Boot 全局异常处理
java·spring boot·后端·全局异常处理·统一返回格式
染落林间色1 小时前
达梦数据库-实时主备集群部署详解(附图文)手工搭建一主一备数据守护集群DW
数据库·sql