对于GenerationType.IDENTITY,JPA持续失败

时间:2012-04-27 18:00:30

标签: java jpa derby jboss6.x

我有一个旧的应用程序在JBOss 5,JPA和Derby中运行良好。我现在将它移植到JBoss 6,只是发现系统无法插入带有错误消息的实体:

列'ID'不能接受NULL值。

其中,ID是标识列:

@Entity
public class Customer {
    @Id 
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    int id;
    ...
}

我检查了生成的架构,看起来不错:

CREATE TABLE "APP"."CUSTOMER" (
    "ID" INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1), 
    "EMAIL" VARCHAR(255), 
    "NAME" VARCHAR(255),
    "PHONE" VARCHAR(255));

您可以在下面的链接中查看应用程序的代码。任何帮助表示赞赏。

https://docs.google.com/open?id=0B_lXBrNTL1s-R3NHb2hYZlJ1Znc

拉​​吉

2 个答案:

答案 0 :(得分:1)

好吧,我把事情搞定了。基本上,当您使用JPA在Derby中生成模式时,它会很好地创建表,但是在插入带有标识列的行时会出现问题。解决方案不是从JPA生成模式。我手动创建了模式并注释掉了模式生成选项。

<persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="ContactsPU" transaction-type="JTA">
    <jta-data-source>java:DerbyDS</jta-data-source>
    <class>com.webage.contacts.Customer</class>
    <!-- 
    <properties>
        <property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect"/>
        <property name="hibernate.hbm2ddl.auto" value="create-drop"/>
    </properties>
     -->
</persistence-unit>
</persistence>

答案 1 :(得分:1)

您无需自行创建方案即可解决此问题。 只需从GenerationType.IDENTITY更改为GenerationType.TABLE。

@GeneratedValue(策略= GenerationType.TABLE)

我在德比中遇到了同样的问题,这解决了它。