- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个实体,它有一个主键/id 字段,如下所示:
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
这很好用。我正在使用 EclipseLink 创建 DDL-Schema,并且该列已正确创建,如下所示:
`id` bigint(20) NOT NULL AUTO_INCREMENT
但是,我确实有几个实体想要自己指定 PK(这是一个将数据从旧数据库传输到我们正在构建的新数据库的小应用程序)。如果我为 POJO 指定 ID(使用 setId(Long id)
)并将其持久化,EclipseLink 不 保存它(即保存记录,但 id 是由 eclipseLink 自动生成)。
有没有办法手动指定具有 @GeneratedValue 的列的值?
这里有一些关于这个问题的想法:
我试图通过完全不使用@GeneratedValue 来解决该问题,而只是手动将列定义为AUTO_INCREMENTed。然而,这迫使我手动提供 ID,总是,因为 EclipseLink 会验证主键(因此它可能不是 null、零或负数)。异常消息显示我应该指定 eclipselink.id_validation,但这似乎没有任何区别(我注释了 @PrimaryKey(validation = IdValidation.NONE)
但仍然得到相同的消息)。
澄清一下:我正在使用 EclipseLink (2.4.0) 作为持久性提供程序,我无法摆脱它(项目的大部分依赖于 eclipselink 特定的查询提示、注释、和类)。
编辑(回应答案):
自定义排序:我尝试实现自己的排序。我尝试继承 DefaultSequence,但 EclipseLink 会告诉我 Internal Exception: org.eclipse.persistence.platform.database.MySQLPlatform 找不到
。但我检查过:该类在类路径上。
所以我继承了另一个类,NativeSequence:
public class MyNativeSequence extends NativeSequence {
public MyNativeSequence() {
super();
}
public MyNativeSequence(final String name) {
super(name);
}
@Override
public boolean shouldAlwaysOverrideExistingValue() {
return false;
}
@Override
public boolean shouldAlwaysOverrideExistingValue(final String seqName) {
return false;
}
}
但是,我得到的是以下内容:
javax.persistence.RollbackException: Exception [EclipseLink-7197] (Eclipse Persistence Services - 2.4.0.v20120608-r11652): org.eclipse.persistence.exceptions.ValidationException
Exception Description: Null or zero primary key encountered in unit of work clone [de.dfv.datenbank.domain.Mitarbeiter[ id=null ]], primary key [null]. Set descriptors IdValidation or the "eclipselink.id-validation" property.
at org.eclipse.persistence.internal.jpa.transaction.EntityTransactionImpl.commitInternal(EntityTransactionImpl.java:102)
...
Caused by: Exception [EclipseLink-7197] (Eclipse Persistence Services - 2.4.0.v20120608-r11652): org.eclipse.persistence.exceptions.ValidationException
Exception Description: Null or zero primary key encountered in unit of work clone [de.dfv.datenbank.domain.Mitarbeiter[ id=null ]], primary key [null]. Set descriptors IdValidation or the "eclipselink.id-validation" property.
at org.eclipse.persistence.exceptions.ValidationException.nullPrimaryKeyInUnitOfWorkClone(ValidationException.java:1451)
...
(为清楚起见缩短了堆栈跟踪)。这与我之前收到的消息相同。我不应该继承 NativeSequence 吗?如果是这样,我不知道为 Sequence 或 StandardSequence 中的抽象方法实现什么。
还可能值得注意的是,只需子类化(不覆盖任何方法)该类就可以按预期工作。但是,在 shouldAlwaysOverrideExistingValue(...)
中返回 false 根本不会生成单个值(我单步执行了该程序并且 getGeneratedValue()
没有被调用一次)。
此外,当我在事务中插入 8 个某种实体时,它会在数据库中产生 11 条记录(到底是什么?!)。
编辑(2012-09-01):我仍然没有解决问题的方法,实现我自己的序列并没有解决它。我需要的是一种能够不显式设置 Id(因此它将自动生成)并且能够显式设置 Id(因此它将用于在数据库中创建记录)的方法。
我尝试将列定义为自己的 auto_increment 并省略 @GeneratedValue,但是验证将启动并且不允许我保存这样的实体。如果我指定一个值 != 0 和 != 零,mysql 会提示主键重复。
我想尝试的想法和选择已经不多了。任何? (开始赏金)
最佳答案
这适用于 eclipselink。它将为序列创建一个单独的表,但这不应该造成问题。
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="id", insertable=true, updatable=true, unique=true, nullable=false)
private Long id;
GenerationType.AUTO 将选择理想的生成策略。由于该字段被指定为可插入和可更新,因此将使用 TABLE 生成策略。这意味着 eclipselink 将生成另一个保存当前序列值的表并生成序列本身,而不是将其委托(delegate)给数据库。由于该列被声明为可插入的,如果持久化时 id 为空,eclipselink 将生成 id。否则将使用现有的 id。
关于java - 在 JPA @GeneratedValue 列中手动指定主键的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12002260/
我是 hibernate 新手。我不明白以下两种主键生成策略: 身份 顺序 有人能解释一下这两者是如何工作的吗?这两者有什么区别? 最佳答案 引用 Java Persistence/Identity
问题: 我想在 hibernate 中映射以下内容 我在实现用户表时得到的错误是: 无法通过 User.id 的反射 setter 设置字段值 我正在使用 MySql 并且字段 ID 是自动递增的 @
我的 hibernate 配置如下: Entity @Table (name = "statuspaatelling") public class StatusPaaTelling { private
我有如下所示的实体,但无法理解为什么当我添加新记录时,生成的 ID 为 50、51、52... 如果 select nextval('seq_text'); 返回 1523 , 1524... 数据库
我有一个实体,它有一个非键列,我已将其设置为在我的数据库中自动生成。 我不能使用 @GeneratedValue,因为据我所知,它仅适用于关键字段。 在这种情况下,如何指示非键列是自动生成的? 最佳答
我的本地 postgres 数据库中有 10-15 个实体。 所有实体都包含一个整数类型的标识。请参阅下面的代码片段。 @Id @GeneratedValue(strategy = Generatio
这是我的实体: @Entity @Table @NoArgsConstructor @AllArgsConstructor @Setter @Getter public class Sample {
我很难找到对@GeneratedValue 的准确解释以及从数据库的角度来看发生的事情的不同策略。 是否总是查询数据库并返回最后一个可用值?如果 2 个不同的进程(不同的 Hibernate 应用程序
我正在开发一个必须部署在多个环境中的应用程序,使用不同的 RDBMS,即 MySQL、MariaDB 和 Oracle。这意味着不同的 ID 生成模式(自动递增与序列)。 JPA 应该允许从 RDBM
我有这个用户类 @Entity public class User { @Id @GeneratedValue(strategy=GenerationType.SEQUENCE)
我使用 MyEclipse 中的 Scaffolding 生成 Web 应用程序项目,使用 spring MVC 和 MySQL 数据库。请给我一些解决问题的线索。 我遇到了 id 主键的问题。如果我
我设置我的实体属性 @GeneratedValue Long id; 并且我能够为数据库中的实体生成 ID。我的问题是为什么所有实体都共享相同的增量数字? 不是每个表都应该从零开始计数吗? 最佳答案
我试图用我想从数据库序列填充的属性来持久化一个实体。我正在使用 Oracle,已经创建了序列,通过 sql 验证了序列有效,但我的属性没有被填充。这是我所拥有的: @GeneratedValue(ge
我正在使用 hibernate 为表自动生成 ID,但我需要手动插入一些与另一个表相关的行(大约 10k,一次)。我正在使用 Oracle 数据库。我怎样才能做到这一点? hibernate 如何生成
JPA规范对注解@GeneratedValue(strategy=TABLE)给出了如下解释: The TABLE generator type value indicates that the pe
我有一个 hibernate 实体父类(super class): @MappedSuperclass public abstract class Pojo_Entity_SuperClass {
我真的很难理解为什么当表已经提供 auto_increment 时还要使用 @ generatedValue 来自动递增。有人可以向我解释一下吗? 最佳答案 @GenerateValue 用于通知 J
我是 postgresql 的新手。 在使用 Ebean 的 playframework 中,我使用了 mysql 和自动生成的值,在那种情况下实际上是自动递增的。我得到的序列是 1,2,3,4...
我正在使用 JPA 的 EclipseLink 实现,但遇到了问题。 这是我的实体类: @Entity@Table(name = "attendances")public class Attendan
我正在使用 JPA,当我将数据插入数据库时,我的 ID 会自动增加 50。我正在使用 persistence.GeneratedValue 来自动增加它: 这是我的模型/实体类的样子(要插入的实体
我是一名优秀的程序员,十分优秀!