- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先,我使用 HBase 0.94.5(也尝试过 0.92.2,结果相同)。
我遇到这样的情况:
变量类:
@Entity
@Table(name = "variable", schema = "keyspace@hbase-pu")
public class Variable {
@Id
private String Id;
@Column(name = "Name")
private String Name;
@ElementCollection(fetch = FetchType.EAGER)
//@CollectionTable(name = "datavalues") // Doesn't work with or without.
private List<DataValue> DataValues;
// Getters and setters omitted.
}
DataValue 类:
@Embeddable
public class DataValue {
@Column(name = "Value")
private Object Value;
// Getters and setters omitted.
}
现在,存储它完全没有问题,但是当我想检索它时,爆炸就会发生。抛出此异常:
原因:org.datanucleus.exceptions.NucleusUserException:无法找到 ID 为空的对象!
Exception in thread "main" javax.persistence.PersistenceException: Unable to find the object with a null id!
at org.datanucleus.api.jpa.NucleusJPAHelper.getJPAExceptionForNucleusException(NucleusJPAHelper.java:414)
at org.datanucleus.api.jpa.JPAQuery.getResultList(JPAQuery.java:203)
at Main.main(Main.java:73)
Caused by: org.datanucleus.exceptions.NucleusUserException: Unable to find the object with a null id!
at org.datanucleus.ExecutionContextImpl.findObject(ExecutionContextImpl.java:3441)
at org.datanucleus.store.hbase.fieldmanager.FetchFieldManager.fetchObjectField(FetchFieldManager.java:287)
at org.datanucleus.state.JDOStateManager.replacingObjectField(JDOStateManager.java:2178)
at Variable.jdoReplaceField(Variable.java)
at Variable.jdoReplaceFields(Variable.java)
at org.datanucleus.state.JDOStateManager.replaceFields(JDOStateManager.java:3415)
at org.datanucleus.state.JDOStateManager.replaceFields(JDOStateManager.java:3442)
at org.datanucleus.store.hbase.query.HBaseQueryUtils$2.fetchFields(HBaseQueryUtils.java:270)
at org.datanucleus.state.JDOStateManager.loadFieldValues(JDOStateManager.java:2547)
at org.datanucleus.state.JDOStateManager.initialiseForHollow(JDOStateManager.java:298)
at org.datanucleus.state.ObjectProviderFactoryImpl.newForHollow(ObjectProviderFactoryImpl.java:89)
at org.datanucleus.ExecutionContextImpl.newObjectProviderForHollowPopulated(ExecutionContextImpl.java:1237)
at org.datanucleus.ExecutionContextImpl.findObject(ExecutionContextImpl.java:3053)
at org.datanucleus.store.hbase.query.HBaseQueryUtils.getObjectUsingApplicationIdForResult(HBaseQueryUtils.java:265)
at org.datanucleus.store.hbase.query.HBaseQueryUtils.getObjectsOfType(HBaseQueryUtils.java:194)
at org.datanucleus.store.hbase.query.HBaseQueryUtils.getObjectsOfCandidateType(HBaseQueryUtils.java:93)
at org.datanucleus.store.hbase.query.JPQLQuery.performExecute(JPQLQuery.java:327)
at org.datanucleus.store.query.Query.executeQuery(Query.java:1786)
at org.datanucleus.store.query.Query.executeWithMap(Query.java:1690)
at org.datanucleus.api.jpa.JPAQuery.getResultList(JPAQuery.java:186)
... 1 more
这是因为 ElementCollection,当我删除它时,它会从 HBase 完美地检索变量类。我还尝试了 Kundera 2.4(相同的示例代码),它比 DataNucleus 'enhance' 更容易设置,但它会抛出 Stream 异常。这两个网站都显示了与我上面的代码类似的代码示例,所以我很好奇我在这里做错了什么。
相关pom.xml:
<dependency>
<groupId>org.apache.geronimo.specs</groupId>
<artifactId>geronimo-jpa_2.0_spec</artifactId>
<version>1.1</version>
</dependency>
<dependency>
<groupId>javax.jdo</groupId>
<artifactId>jdo-api</artifactId>
<version>3.0</version>
</dependency>
<dependency>
<groupId>org.datanucleus</groupId>
<artifactId>datanucleus-core</artifactId>
<version>3.2.1</version>
</dependency>
<dependency>
<groupId>org.datanucleus</groupId>
<artifactId>datanucleus-api-jpa</artifactId>
<version>3.2.0-release</version>
</dependency>
<dependency>
<groupId>org.datanucleus</groupId>
<artifactId>datanucleus-hbase</artifactId>
<version>3.2.0-release</version>
</dependency>
<dependency>
<groupId>org.datanucleus</groupId>
<artifactId>datanucleus-enhancer</artifactId>
<version>3.1.1</version>
</dependency>
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>persistence-api</artifactId>
<version>2.0</version>
</dependency>
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-core</artifactId>
<version>1.1.2</version>
<exclusions>
<exclusion>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
</exclusion>
<exclusion>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-asl</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.hbase</groupId>
<artifactId>hbase</artifactId>
<version>0.94.5</version>
</dependency>
<plugin>
<groupId>org.datanucleus</groupId>
<artifactId>datanucleus-maven-plugin</artifactId>
<version>3.2.0-release</version>
<configuration>
<api>JPA</api>
<persistenceUnitName>hbase-pu</persistenceUnitName>
<verbose>true</verbose>
</configuration>
<executions>
<execution>
<phase>process-classes</phase>
<goals>
<goal>enhance</goal>
</goals>
</execution>
</executions>
</plugin>
DataNucleus 的 persistance.xml:
<persistence 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_2_0.xsd" version="2.0">
<!-- JPA tutorial "unit" -->
<persistence-unit name="hbase-pu" transaction-type="RESOURCE_LOCAL">
<provider>org.datanucleus.api.jpa.PersistenceProviderImpl</provider>
<class>Variable</class>
<class>DataValue</class>
<exclude-unlisted-classes>true</exclude-unlisted-classes>
<properties>
<property name="datanucleus.storeManagerType" value="hbase" />
<property name="datanucleus.ConnectionURL" value="hbase:localhost:2281"/>
<property name="datanucleus.ConnectionUserName" value=""/>
<property name="datanucleus.ConnectionPassword" value=""/>
<property name="datanucleus.autoCreateSchema" value="true"/>
<property name="datanucleus.autoCreateTables" value="true" />
<property name="datanucleus.autoCreateColumns" value="true" />
<property name="datanucleus.validateTables" value="true"/>
<property name="datanucleus.validateConstraints" value="false"/>
<property name="datanucleus.Optimistic" value="false"/>
<property name="datanucleus.Multithreaded" value="true" />
</properties>
</persistence-unit>
</persistence>
昆德拉的persistence.xml:
<persistence 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
https://raw.github.com/impetus-opensource/Kundera/Kundera-2.0.4/kundera-core/src/test/resources/META-INF/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="hbase-pu">
<provider>com.impetus.kundera.KunderaPersistence</provider>
<properties>
<property name="kundera.nodes" value="localhost" />
<property name="kundera.port" value="2182" />
<property name="kundera.keyspace" value="keyspace" />
<property name="kundera.dialect" value="hbase" />
<property name="kundera.client.lookup.class" value="com.impetus.client.hbase.HBaseClientFactory" />
<property name="kundera.cache.provider.class" value="com.impetus.kundera.cache.ehcache.EhCacheProvider" />
<property name="kundera.cache.config.resource" value="/ehcache-test.xml" />
<property name="kundera.ddl.auto.prepare" value="update" />
</properties>
</persistence-unit>
</persistence>
我对这整件事有点茫然,我有一种感觉,我此时几乎尝试了一切,但不知道如何继续。
-- 请参阅下面的评论。
新变量类:
@Entity
@Table(name = "variable", schema = "keyspace@hbase-pu")
public class Variable {
@Id
private String Id;
@Column(name = "Name")
private String Name;
@ElementCollection(fetch = FetchType.EAGER)
private List<Object> DataValues;
@Column(name = "Value")
@Lob
private Object Value;
// Getters and setters omitted.
}
最佳答案
所以你想要一个嵌入式集合吗?但随后如 this page shows clearly enough ,目前 HBase 不支持这一点(MongoDB 支持,但它有更灵活的数据存储结构来允许它)。您可以拥有非实体的集合(与所有者保留在同一个 HTable 中),也可以拥有(非嵌入)实体的集合,但不能拥有嵌入的集合。显然,如果这对您很重要,您可以贡献您的时间来提供支持(我什至会为您提供代码中的起点以供查看)。
没有理由说“CollectionTable”会有所不同......它是 RDBMS 模式的注释(但 JPA 是专为 RDBMS 设计的)。
PS 1,这个“增强功能”就像在 pom.xml 中添加“插件” block 一样简单。因此,除非您准备好向 DataNucleus 项目表达您的困难是什么,否则他们怎么会知道。
PS 2,如果报告问题,我希望您显示异常+堆栈跟踪,无论涉及什么软件,因为从异常消息中您告诉人们的信息很少。
关于java - DataNucleus/Kundera 与 HBase 和 ElementCollection - 无法找到具有 null id 的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15781113/
我的代码符合要求,但是当我尝试运行 DataNucleus 增强器时,我无法完成后编译步骤。我想我丢失了一个 jar 文件,但是是哪个??我已经包含了错误和 pom.xml 我从谷歌页面复制说明:
当为 Google App Engine 运行 Maven 构建时,我收到构建错误: org.apache.maven.plugin.MojoExecutionException: The DataN
我在我的 appengine java 应用程序中使用查询游标,如下所述: https://cloud.google.com/appengine/docs/java/datastore/jdo/que
考虑使用具有以下持久性结构的 DataNucleus 的应用程序: 你有一个类有两个属性,比如 created (Date) 和 lastUpdate (Date):当这个类的对象将被提交时,你如何自
对于上下文,客户端我使用 MVP 模式,因此具有 One 列表的 View 仅知道 ID,并且当我的新 Many 收到时服务器,我希望能够使用“setOneId”或 ID 设置为所需值的空 One 对
我有这些注释: public class Account { @Persistent(defaultFetchGroup = "true", dependent = "false") @Column(
使用 DataNucleus,我很高兴使用抽象基类为子类提供“长”ID(请注意原始类型)。 当调整 example from JPA 时我想到了参数化基类。目的是支持不同的 ID 类型,例如 Stri
我试图用 datanucleus jdo(和 neodatis 作为数据存储)制作一些基本的持久类。 我有以下三个类(从教程中复制) 库存.java @PersistenceCapable publi
DataNucleus 支持缓存协调吗?如果是,我该如何启用和使用它? 我还没有积极使用 DataNucleus,但如果它支持缓存协调,我想考虑它。 背景:多个缓存实例使用缓存协调来相互通知已更改的实
我有两个不同的数据源,我需要两个不同的 PersistenceManagerFactory。这一点我总是可以通过编写一个 persistence.xml 文件来实现。但我希望以编程方式表示它。尽管第二
如何使用 Eclipse maven 项目解决此问题: Plugin execution not covered by lifecycle configuration: org.datanucleus
我正在尝试将 JDBC webapp 移动到 JDO DataNucleus 2.1.1。 假设我有一些看起来像这样的类: 公共(public)类职位{ 私有(private)整数 id; 私有(pr
我正在尝试将 Maven 项目迁移到 Bazel,但在 Datanucleus 增强方面遇到了麻烦。 后 jar -file 已构建,Datanucleus 会查看其中的内部并执行一些字节码操作以增强
使用 JDO 和 DataNucleus 如果我有一个 @PersistenceCapable 类,例如 @PersistenceCapable public class Topic {
如果我没看错的话,它是说NeoDatis 不支持 JDO 获取组。我的解释正确吗? 在 NeoDatis 的 DataNucleus 页面上: The following are known limi
我有一个包含 Map 的类,但是当我尝试保留这个实体时,会抛出空指针异常。我的代码/设置可能有什么问题? 我的类(class): @PersistenceCapable(detachable="tru
我创建了一个转换器插件,如描述的 here对于 X 型。 然后我创建了该类 class A { @Basic(fetch = FetchType.Eager) X x; } 当我尝试保
DataNucleus.JDO - All messages general to JDO DataNucleus.JPA - All messages general to JPA DataNucl
我正在使用带有 JDO(DataNucleus) 的 GAE 1.7.0。当我保留一个具有集合属性的类时,已删除的集合成员不会从数据存储中删除。我从分离的副本中删除集合成员。新成员已正确添加,现有成员
我正在尝试使用 DataNucleus 和 MySQL 创建一个 Maven 项目。但是,当我尝试构建和 mvn datanucleus:schema-create项目,我失败了。我不明白为什么。 这
我是一名优秀的程序员,十分优秀!