惟愿此间无白头 2020-04-19 22:49 采纳率: 0%
浏览 185

JPA 主键生成策略为 Table 时,初始主键值为什么不是预期的值?

各位大佬帮帮小弟吧。求求了!!!

@Id
@GeneratedValue(strategy = GenerationType.TABLE, generator = "ID_GENERATOR")
@TableGenerator(name = "ID_GENERATOR", table = "jpa_id_generators", pkColumnName = "PK_NAME", pkColumnValue = "CUSTOMER_ID", valueColumnName = "PK_VALUE")
public Integer getId() {
    return id;
}

图片说明

Customer customer = new Customer();
customer.setAge(19);
customer.setEmail("tc@qq.com");
customer.setLastName("tc");
customer.setCreatedTime(new Date());
customer.setBirth(new Date());
entityManager.persist(customer);

按理来说,allocationSize 默认为 50,initialValue 默认为 0,不写的话 id 就是从 50 开始。实际上是从 -47 开始。allocationSize 我赋值为 100,id 就从 -97开始,这是怎么回事?
图片说明

这是配置文件:

<persistence-unit name="jpa-1" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
<!-- 添加持久化类 -->
<class>jpa.helloworld.Customer</class>
    <properties>
        <property name="hibernate.connection.url" value="jdbc:mysql:///jpa?serverTimezone=UTC"/>
            <property name="hibernate.connection.driver_class" value="com.mysql.cj.jdbc.Driver"/>
            <property name="hibernate.connection.username" value="root"/>
            <property name="hibernate.connection.password" value="1024"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
            <property name="hibernate.show_sql" value="true"/>
            <property name="hibernate.format_sql" value="true"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
    </properties>
</persistence-unit>
  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 01:32
    关注

    根据您提供的代码和配置,主键生成策略为 Table 时,初始主键值为不符合预期的情况是因为在使用 TableGenerator 时出现了数据冲突,导致分配的 ID 不是按顺序递增的。

    解决方法是在 table 属性中指定不同的名字,例如:

    @TableGenerator(name = "ID_GENERATOR", table = "CUSTOMER_TABLE_GENERATOR", ...)
    

    同时,在数据库中创建相应的表 CUSTOMER_TABLE_GENERATOR,并清空该表的数据,以确保初始化的主键值为预期值。若已经有大量数据,可以通过建立新的表并将数据备份到新表中来解决冲突。

    评论

报告相同问题?

悬赏问题

  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
  • ¥50 C++五子棋AI程序编写
  • ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。
  • ¥15 SQL Server analysis services 服务安装失败
  • ¥15 基于面向对象的图书馆借阅管理系统
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥20 centos linux 7.9安装php8.2.18不支持mysqli模块的问题