WEB9031 - 无法存储序列生成id的实体

时间:2013-03-22 13:52:28

标签: jpa glassfish ejb

我正在使用glassfish,postgres和openjpa。

我只有一个bean,并且首先要创建一个新的intance并将其存储在DB中。我创建了一个新的用户对象,填充它(除了id)并得到 - 试图坚持 - 跟踪异常:

Caused by: java.lang.IllegalStateException: WEB9031: WebappClassLoader unable to load resource [org.apache.openjpa.util.LongId], because it has not yet been started, or was already stopped
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1401)
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1359)
at org.myPlace.server.user.UserPDO.pcNewObjectIdInstance(UserPDO.java)
at org.apache.openjpa.enhance.PCRegistry.newObjectId(PCRegistry.java:142)
at org.apache.openjpa.meta.MetaDataRepository.processRegisteredClass(MetaDataRepository.java:1694)
at org.apache.openjpa.meta.MetaDataRepository.processRegisteredClasses(MetaDataRepository.java:1644)
... 128 more

 WARNING: StandardWrapperValve[Faces Servlet]: PWC1406: Servlet.service() for
 servlet Faces Servlet threw exception
 java.lang.IllegalStateException: WEB9031: WebappClassLoader unable to load resource   
 [org.apache.openjpa.util.LongId], because it has not yet been started, or was already stopped
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1401)
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1359)
at org.myPlace.server.user.UserPDO.pcNewObjectIdInstance(UserPDO.java)
at org.apache.openjpa.enhance.PCRegistry.newObjectId(PCRegistry.java:142)
at org.apache.openjpa.meta.MetaDataRepository.processRegisteredClass(MetaDataRepository.java:1694)

我的bean看起来像这样:

@Entity
@Table(name="tbl_User")
public class UserPDO implements Serializable {

private long id;
private String username;
private String password;

public UserPDO() {}

@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE, generator="user_seq_gen") 
@SequenceGenerator(name="user_seq_gen", sequenceName="user_seq")
public long getId() {
    return id;
}

public void setId(long id) {
    this.id = id;
}

... }

我的persistence.xml如下所示:

<?xml version="1.0" encoding="UTF-8"?>

<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="myPlace" transaction-type="JTA">

    <provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider>

    <class>org.myPlace.server.user.UserPDO</class>

    <properties>
      <property name="openjpa.jdbc.DBDictionary" value="postgres"/>

      <property name="openjpa.ConnectionDriverName" value="org.postgresql.Driver"/>
      <property name="openjpa.ConnectionURL" value="jdbc:postgresql://localhost:5432/myPlace"/>
      <property name="openjpa.ConnectionPassword" value="myPlace"/>
      <property name="openjpa.ConnectionUserName" value="myPlace"/>

      <property name="openjpa.jdbc.SynchronizeMappings" value="buildSchema"/> 
      <property name="openjpa.Log" value="File=/home/username/apache.log, DefaultLevel=ERROR, Tool=INFO, SQL=TRACE"/>

      <property name="openjpa.DynamicEnhancementAgent" value="false" />
      <property name="openjpa.RuntimeUnenhancedClasses" value="unsupported" />
      <property name="openjpa.DataCache" value="false"/>
      <property name="openjpa.QueryCache" value="false"/>
    </properties>

</persistence-unit> 

正确创建表,序列也是如此。但是当我想通过

创建一个新的用户对象时
public <T> T create(T t) {
    this.em.persist(t);
    this.em.flush();
    this.em.refresh(t);
    return t;
}

我得到了上面提到的例外。我在这里发现了一些问题/答案,表明deactiving运行时增强应该可以解决问题。但它对我不起作用。我的第一个想法是,它可能是一个Classloader-Leak。我将postgres-driver和openjpa-jars复制到glassfish / lib-folder中。

有人可以帮忙吗?谢谢!

0 个答案:

没有答案