与MongoDB的Eclipselink - 强制转换异常

时间:2014-03-31 09:34:46

标签: java mongodb jpa persistence eclipselink

我在为Mongodb配置JPA时遇到困难。

这是我的堆栈异常:

[EL Config]: connection: 2014-03-31 10:48:24.171--ServerSession(1883377923)--Connection(1001688235)--Thread(Thread[main,5,smarttrade])--disconnect
[EL Severe]: ejb: 2014-03-31 10:48:24.181--ServerSession(1883377923)--Thread(Thread[main,5,smarttrade])--java.lang.ClassCastException: org.eclipse.persistence.nosql.adapters.mongo.MongoPlatform cannot be cast to org.eclipse.persistence.internal.databaseaccess.DatabasePlatform
    at org.eclipse.persistence.sequencing.TableSequence.onConnect(TableSequence.java:168)
    at org.eclipse.persistence.sequencing.Sequence.onConnect(Sequence.java:270)
    at org.eclipse.persistence.internal.sequencing.SequencingManager.onConnectSequences(SequencingManager.java:927)
    at org.eclipse.persistence.internal.sequencing.SequencingManager.onConnectInternal(SequencingManager.java:747)
    at org.eclipse.persistence.internal.sequencing.SequencingManager.onConnect(SequencingManager.java:700)
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.initializeSequencing(DatabaseSessionImpl.java:282)
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.initializeDescriptors(DatabaseSessionImpl.java:636)
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.initializeDescriptors(DatabaseSessionImpl.java:632)
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.initializeDescriptors(DatabaseSessionImpl.java:568)
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.postConnectDatasource(DatabaseSessionImpl.java:799)
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.login(DatabaseSessionImpl.java:756)
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryProvider.login(EntityManagerFactoryProvider.java:241)
    at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:685)
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getAbstractSession(EntityManagerFactoryDelegate.java:204)
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.createEntityManagerImpl(EntityManagerFactoryDelegate.java:304)
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManagerImpl(EntityManagerFactoryImpl.java:336)
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:302)
    at com.smarttrade.tick.engine.TickEngine.start(TickEngine.java:287)

我的persistence.xml定义如下:

<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_2_0.xsd"
   version="2.0" xmlns="http://java.sun.com/xml/ns/persistence">
   <persistence-unit name="mongo" transaction-type="RESOURCE_LOCAL">
      <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
      <class>com.smarttrade.tick.jpa.Instrument</class>
      <class>com.smarttrade.tick.jpa.Snapshot</class>
      <exclude-unlisted-classes>false</exclude-unlisted-classes>
      <properties>
         <property name="eclipselink.target-database"
            value="org.eclipse.persistence.nosql.adapters.mongo.MongoPlatform" />
         <property name="eclipselink.nosql.connection-spec"
            value="org.eclipse.persistence.nosql.adapters.mongo.MongoConnectionSpec" />
         <property name="eclipselink.nosql.property.mongo.port" value="27017" />
         <property name="eclipselink.nosql.property.mongo.host" value="localhost" />
         <property name="eclipselink.nosql.property.mongo.db" value="mydb" />
         <property name="eclipselink.logging.level" value="FINEST" />
      </properties>
   </persistence-unit>
</persistence>

我有两个实体类:

@Entity
@NoSql(dataFormat = DataFormatType.MAPPED)
public class Instrument {

    @Id
    String securityID = null;

    @OneToMany(cascade = { CascadeType.PERSIST, CascadeType.MERGE, CascadeType.DETACH })
    Set<Snapshot> snapshots = new HashSet<Snapshot>();

    // constructor, getters and setters 
    ...
}

@Entity
@Inheritance(strategy = InheritanceType.JOINED)
@NoSql(dataFormat = DataFormatType.MAPPED)
public class Snapshot {

    @Id
    @GeneratedValue(strategy = GenerationType.TABLE)
    double id;

    @Temporal(TemporalType.TIMESTAMP)
    Date snapshotTs;

    String bestOfferOwn;
    .. // other fields

    // constructor, getters and setters 
    ...
}

这就是我的称呼方式:

EntityManagerFactory factory = Persistence.createEntityManagerFactory("mongo");
EntityManager em = factory.createEntityManager();
em.getTransaction().begin();
Instrument i = new Instrument("JAP_USDEUR");
Snapshot s = new Snapshot(new Date(), "LP_one", 20000, 3.1, new Date(), "LP_two", 10000, 3.0, new Date());
Snapshot s2 = new Snapshot(new Date(), "LP_rg", 500, 4.9, new Date(), "LP_zet", 6000, 5.1, new Date());
i.getSnapshots().add(s);
i.getSnapshots().add(s2);
em.persist(i);

em.getTransaction().commit();
em.close();

工厂已创建,然后似乎EntityManager建立连接,但在我有此强制转换异常之后。我发现了一篇关于它的帖子(Eclipselink with MongoDB java.lang.ClassCastException),但我已经在persistence.xml中添加了这些类。

就像我在jpa中真的是个新手一样,我可能会犯错,但我找不到什么。

1 个答案:

答案 0 :(得分:0)

我终于找到了问题所在。我为我的Snaphot的Id生成策略使用了GenerationType.TABLE,但是在nosql中不支持。 我刚刚改变了:

@Id
@GeneratedValue(strategy = GenerationType.TABLE)
double id;

@Id
@GeneratedValue
double id;

并且有效