- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将 JDBC webapp 移动到 JDO DataNucleus 2.1.1。
假设我有一些看起来像这样的类:
公共(public)类职位{
私有(private)整数 id;
私有(private)字符串标题;
}
公共(public)类员工{
私有(private)整数 id;
私有(private)字符串名称;
私有(private)职位职位;
}
Position SQL 表的内容确实不会经常更改。使用 JDBC,我将整个表读入内存(能够定期或随意刷新)。然后,当我将 Employee 读入内存时,我只需从 Employee 表中检索职位 ID 并使用它来获取内存中的 Position 实例。
但是,使用 DataNucleus,如果我遍历所有位置:
Extent<Position> extent =pm.getExtent(Position.class, true);
Iterator<Position> iter =extent.iterator();
while(iter.hasNext()) {
Position position =iterPosition.next();
System.out.println(position.toString());
}
Extent<Employee> extent =pm.getExtent(Employee.class, true);
Iterator<Employee> iter =extent.iterator();
while(iter.hasNext()) {
Employee employee =iter.next();
System.out.println(employee.getPosition());
}
<jdo>
<package name="com.example.staff">
<class name="Position" identity-type="application" schema="MYSCHEMA" table="Position">
<inheritance strategy="new-table"/>
<field name="id" primary-key="true">
<column name="ID" jdbc-type="integer"/>
</field>
<field name="title">
<column name="TITLE" jdbc-type="varchar"/>
</field>
</class>
</package>
</jdo>
<jdo>
<package name="com.example.staff">
<class name="Employee" identity-type="application" schema="MYSCHEMA" table="EMPLOYEE">
<inheritance strategy="new-table"/>
<field name="id" primary-key="true">
<column name="ID" jdbc-type="integer"/>
</field>
<field name="name">
<column name="NAME" jdbc-type="varchar"/>
</field>
<field name="position" table="Position">
<column name="POSITION_ID" jdbc-type="int" />
<join column="ID" />
</field>
</class>
</package>
</jdo>
SELECT 'com.example.staff.Employee' AS NUCLEUS_TYPE,A0.ID,A0."NAME",A0.POSITION_ID,B0.ID,B0.TITLE FROM MYSCHEMA.EMPLOYEE A0 LEFT OUTER JOIN MYSCHEMA."POSITION" B0 ON A0.POSITION_ID = B0.ID
最佳答案
默认情况下,从数据存储中获取 Employee 实体时不会进行连接,只有在实际读取 Employee.position 时才会进行连接(这称为延迟加载)。
此外,使用 level 2 cache 可以避免第二次提取。 .首先检查二级缓存是否实际启用(在 DataNucleus 1.1 中默认禁用,在 2.0 中默认启用)。然后,您可能应该“固定”该类,以便将其位置实体无限期地缓存:
但是,如果其他应用程序使用相同的数据库,二级缓存可能会导致问题,因此我建议仅对很少更改的类(例如位置)启用它。对于其他类,将“cacheable”属性设置为 false(默认为 true)。
编辑添加:
元数据中的
<field name="position" default-fetch-group="true">
<column name="POSITION_ID" jdbc-type="int" />
</field>
SELECT 'com.example.staff.Position' AS NUCLEUS_TYPE,`THIS`.`ID`,`THIS`.`TITLE` FROM `POSITION` `THIS` FOR UPDATE
SELECT 'com.example.staff.Employee' AS NUCLEUS_TYPE,`THIS`.`ID`,`THIS`.`NAME`,`THIS`.`POSITION_ID` FROM `EMPLOYEE` `THIS` FOR UPDATE
SELECT 'com.example.staff.Employee' AS NUCLEUS_TYPE,`THIS`.`ID`,`THIS`.`NAME`,`THIS`.`POSITION_ID` FROM `EMPLOYEE` `THIS` FOR UPDATE
SELECT `A0`.`TITLE` FROM `POSITION` `A0` WHERE `A0`.`ID` = <2> FOR UPDATE
SELECT `A0`.`TITLE` FROM `POSITION` `A0` WHERE `A0`.`ID` = <1> FOR UPDATE
关于jdo - 避免 DataNucleus 连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3224584/
我的代码符合要求,但是当我尝试运行 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项目,我失败了。我不明白为什么。 这
我是一名优秀的程序员,十分优秀!