答复: 关于JPA吐个槽,关于ID生成策略的

鉴于各位的建议,看了一下spring data的资料。
找到了 org.springframework.data.jpa.domain.AbstractPersistable
(幻无极说的不准确。Persistable,只是声明这个类用id作为主键属性,并未声明ID生成策略)

仔细看了一下,AbstractPersistable的ID生成策略是 javax.persistence.GenerationType.AUTO
按照文档,这个策略并不是由数据库自动生成,而是容器自动生成。
请注意 这个容器其实是jpa容器,也就是entitymanager的容器。

当然,如果使用entitymanager的容器的自动生成,确实是与数据库无关,
只是不合我这种强迫症患者的口味而已。

另外,以前研究jpa时发现jpa不能识别entity父类的annotation,
本来以为是不支持,现在看到,是要用
@javax.persistence.MappedSuperclass加在类声明上。

(Very good,又可以考虑实现JPA的代码生成工具了。)

因此,可以实现自己的entity统一基类,加上MappedSuperclass,就是 superchinaren 所说的IDEntity。

剩下还有一个疑问,如果在父类中声明ID生成策略为 GenerationType.SEQUENCE。
这个sequence名称是按类建的,还是统一的一个呢?
有空做下实验......
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPAJava 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、付费专栏及课程。

余额充值