- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个 AppEngine 项目,并且在 AppEngine 数据存储之上使用 JDO 来实现持久性。我有一个实体,它使用编码字符串作为键,还使用应用程序生成的键名(也是一个字符串)。我这样做是因为我的应用程序会经常从野外获取数据(可能会获取相同的数据)并尝试保留它们。为了避免持久化本质上包含相同数据的多个实体,我决定对这些数据的一些属性进行哈希处理,以获得一致的键名(由于实体关系而不是直接操作键)。现在的问题是,每当我计算散列(键名)并尝试存储实体时,如果它已经存在于数据存储中,则数据存储(或 JDO 或罪魁祸首是谁)会默默地覆盖数据存储中实体的属性,而不会引发任何异常。这对应用程序有严重影响,因为它覆盖了实体(我们用于排序)的时间戳(字段)。我怎样才能最好地解决这个问题?
最佳答案
您需要执行 get-before-set(检查并设置或 CAS)。
CAS 是并发的基本租户,也是并行计算不可避免的祸害。
无论如何,获取比套装便宜得多,因此实际上可能会省钱。
不要盲目写入数据存储,而是先检索;如果实体不存在,则捕获异常并仅放置实体。如果确实存在,请在保存之前进行深入比较。如果没有任何改变,就不要坚持它(并节省成本)。如果它已更改,请随意选择合并策略。维护过时修订的一种(有点丑陋)方法是将先前的实体存储为更新实体中的字段(可能不适用于许多修订)。
但是,在这种情况下,您必须在设置之前获取。如果您不希望有很多重复项并且想要真正简单,您可以先执行一个存在查询...这是对您要使用的键执行仅键计数查询(成本比完整获取少 7 倍) )。如果 (count() == 0) then put() else getAndMaybePut() fi
计数查询语法可能看起来很慢,但从我的基准来看,它是判断实体是否存在的最快(也是最便宜)的方法:
public boolean exists(Key key){
Query q;
if (key.getParent() == null)
q = new Query(key.getKind());
else
q = new Query(key.getKind(), key.getParent());
q.setKeysOnly();
q.setFilter(new FilterPredicate(
Entity.KEY_RESERVED_PROPERTY, FilterOperator.EQUAL, key));
return 1 == DatastoreServiceFactory.getDatastoreService().prepare(q)
.countEntities(FetchOptions.Builder.withLimit(1));
}
关于java - JDO - 保留两个具有相同 key 的实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14086900/
我想构建一个应用程序,其中由电子邮件地址标识的用户可以拥有多个应用程序帐户。每个帐户可以有一个或多个用户。我正在尝试将 JDO 存储功能与 Google App Engine Java 结合使用。这是
我在 karaf 2.2.10 之上使用带有 datanucleus-mongodb 3.2.3 和 spring 3.0.7 的 JDO。 在新的 OSGi bundle 安装中,我能够在 mong
这些框架(JPOX JDO 和 Cater JDO)是否遵循与 Hibernate 类似的原则?他们是否使用配置数据以及反射和泛型的组合?主要的架构差异有哪些? 最佳答案 Castor JDO 不是“
尝试遵循 DataNucleus HBase tutorial 时出现异常(“必须指定名为 javax.jdo.PersistenceManagerFactoryClass 的属性”) . 我的 da
我正在尝试增强我的 Google App Engine 项目,但我不断收到此错误。在我不得不在我的机器上重新安装操作系统之前它工作得很好,现在它提示这个: [ERROR] Failed to exec
在过去,我们曾经通过存储过程访问数据库。它们被视为管理数据的“更好”方式。我们将数据保存在数据库中,任何语言/平台都可以通过JDBC/ODBC/etc访问。 然而,近年来,基于运行时反射/元数据的存储
在我的 User 类上,我有一个字符串列表字段: @Persistent private List openIds; 当我创建新用户时,我会这样做: User user = new User(); u
我目前正在 GAE 中进行开发,我必须使用 JDO 进行这样的查询: SELECT table1.column1, table2.column2 FROM table1, table2 WHERE t
我有一个 spring 测试用例,注释如下 @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = {"cl
我的 Oracle 数据库中有两个表 请求和批准。每个审批者都有一个请求。受约束保护的外键。 在我使用 kodo jdo 3.4 的 java 代码中,我对部分或全部批准者调用删除持久性。最后,如果没
我最近开始看到 JDO 错误,例如 Class X has been specified with an object-id class javax.jdo.identity.StringIdenti
上课: class Node implements Serializable { private String name; public String getName { return
我有一个我认为是 JDO 中常见的场景。我有一个简单的持久类,比如说 @PersistenceCapable public class Person { @PrimaryKey @Pe
将对象保存到数据库时,我收到 MySQLIntegrityConstraintViolationException 。我知道这个错误意味着什么,但我无法解决它。 错误:引起:com.mysql.jdb
我正在使用 JDO 来查询我的数据库。实体类看起来有点像这样: class Entity { // other members of the class List stuff; // me
我正在使用 JDO 在 Google App Engine 中创建云端点。我有两个实体。用户实体包含组列表。组实体包含作为用户实体的成员列表。 用户实体: @PersistenceCapable(id
我正在试验 Google App Engine 和持久选项 JDO。我想知道是否可以将 transient 对象映射到持久对象?或者使用 transient 对象来更新持久对象? 在编码示例中,我看到
我正在使用连接到 MySQL 数据库的 Spring 和 JDO。当我保留一个对象时,我希望看到由 makePersistent() 方法返回的已创建对象。它确实返回了一个对象,但是这个对象只有新建对
我有两个不同的数据源,我需要两个不同的 PersistenceManagerFactory。这一点我总是可以通过编写一个 persistence.xml 文件来实现。但我希望以编程方式表示它。尽管第二
我正在尝试将 JDBC webapp 移动到 JDO DataNucleus 2.1.1。 假设我有一些看起来像这样的类: 公共(public)类职位{ 私有(private)整数 id; 私有(pr
我是一名优秀的程序员,十分优秀!