插入数据时,获取JPA自定义生成主键策略的id

新增数据时,获取自定义String类型的id

业务需求

新增软文时,将软文的访问路径url拼接id一并存入数据表中,在软文列表可以利用url查看详情

1.项目结构+实体类

在这里插入图片描述

2.生成自定义String类型的id工具类

主要思想:年月日时分秒+5位随机数

package cn.edu.nyist.student.utils;

import org.hibernate.MappingException;
import org.hibernate.engine.spi.SessionImplementor;
import org.hibernate.id.UUIDGenerator;
import java.io.Serializable;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;

public class IDGenerator extends UUIDGenerator {

    @Override
    public Serializable generate(SessionImplementor session, Object object) th
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPA(Java Persistence API)允许开发者自定义主键生成策略。在JPA中,可以使用@GeneratedValue注解来指定主键生成策略。常用的主键生成策略有以下几种: 1. 自增长(GenerationType.IDENTITY):使用数据库自增长字段生成主键,适用于支持自增长的数据库,如MySQL、SQL Server等。 ```java @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; ``` 2. 序列(GenerationType.SEQUENCE):使用数据库序列生成主键,适用于支持序列的数据库,如Oracle。 ```java @Id @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "sequence_name") @SequenceGenerator(name = "sequence_name", sequenceName = "your_sequence_name", allocationSize = 1) private Long id; ``` 3. 表生成(GenerationType.TABLE):使用特定的数据库表来生成主键,适用于各种数据库。 ```java @Id @GeneratedValue(strategy = GenerationType.TABLE, generator = "table_name") @TableGenerator(name = "table_name", table = "your_table_name", pkColumnName = "pk_column_name", valueColumnName = "value_column_name", allocationSize = 1) private Long id; ``` 4. UUID(GenerationType.UUID):使用UUID生成主键,适用于分布式系统或无法依赖数据库自增长功能的场景。 ```java @Id @GeneratedValue(strategy = GenerationType.UUID) private String id; ``` 以上是一些常用的主键生成策略,你可以根据实际需求选择适合的策略。同,也可以通过实现自定义主键生成器来实现更加复杂的主键生成策略

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值