- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在开发一个GAE Web应用程序,我需要创建和删除两个没有祖先关系的实体的实例之间的关联(还考虑到同一个实例可能有多个关联,这些关联可能会随着时间的推移而变化,而祖先关系一旦创建,无法删除)。我经历过“最终一致性”策略,这意味着我的网页中的数据不会与我正在创建/删除的关系一致地刷新。然而,我发现通过执行 put() 方法两次,一致性似乎是强制的。
这符合“最终一致性”定义,该定义指出“...如果没有进行新的更新...”数据最终将保持一致,因为我正在进行另一次更新(实际上是相同的两次)我猜系统会强制保持一致性。
我说得对吗?还有其他更优雅的方法吗?
更新:我的目标
假设我有一个 A 类型实体列表,它们实际代表什么并不重要,假设它们代表我业务的主要实体我有一个 B 类型实体的列表,代表 A 类型实体可以依赖的服务。这是多对多的关系,所以服务 b 可以被许多类型 A 的实体 a 使用实体 a 可以由许多 B 类型的服务 b 提供服务
我有一个网页允许我创建这样的关系(一个 Jinja2 模板,带有来自客户端的 Jquery Ajax 回调和一个依赖于服务器端数据存储的 webapp2 python 请求处理程序)。当从数据存储中删除关系时,我通过对 a 实体进行另一个查询并描述其相关的 b 键列表来刷新数据。在这种情况下,我仍然在与 a 相关的 b 键列表中看到已删除的 b.key。这不是我所期望的。
更新:一些代码
这是模型
class A(ndb.Model):
name = ndb.StringProperty()
services = ndb.KeyProperty(repeated=True)
class B(ndb.Model):
name = ndb.StringProperty()
servedEntities = ndb.KeyProperty(repeated=True)
这是我用来创建关系的代码
a.services.append(b.key);
b.servedEntities.append(a.key);
a.put()
b.put()
这是我用来删除关系的代码
a.services.remove(b.key);
b.servedEntities.remove(a.key);
a.put()
b.put()
a和b之间没有祖先关系(也不可能有)关系删除后,如果再次从数据存储区检索 a,我仍然可以看到 a.services 中列出的 b.key
最佳答案
您的问题的答案在于以下声明:
When a relationship is removed from the datastore I refresh the data by making another query on the a entity.
为什么需要新查询?
假设用户订阅了服务 x、y 和 z。现在,用户告诉您从列表中删除服务 z。您转到数据存储区并进行必要的更改。但是,您可以简单地从客户端的用户实体中删除 z 并相应地更新 UI,而不是运行新的查询(这可能仍会在返回的实体中显示 z)。
这显然是一个简化的示例。当我编写学校安排应用程序时,我遇到了类似的挑战,该应用程序有一个更复杂的用例 - 单个更改可能会影响选定时间段内的许多实体(例如“在每个教学日安排一个类直到季度末”) ,所以我想简单地运行一个新查询来刷新计划 View 。显然,我遇到了最终一致性问题,由于有时必须创建数十个实体,这一问题被放大了。然后我意识到我已经拥有刷新 View 所需的所有数据,而无需运行新查询。虽然代码有点多,但它是一个干净可靠的解决方案。
关于python - Google 应用程序引擎数据存储 : Dealing with eventual consistency,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27633835/
使用 CQRS 和事件存储,微服务之间的编排提供了最终一致性,其中一个微服务中的更改需要一点时间才能传播到其他相关的下游系统(基本上是其他微服务)。 如果数据非常关键以至于两个微服务都应该对数据具有强
我遇到了“强最终一致性”的概念。 它应该比“最终一致性”强但比“强一致性”弱吗?有人可以用适用的例子解释这三个概念之间的区别吗? http://en.wikipedia.org/wiki/Eventu
为什么 AWS 在 DynamoDB 中说“强一致性”而在 S3 中说“写后读一致性”?这两个意思是一样的吗? 最佳答案 这两个术语本质上是同一个东西,从某种意义上说,先读后写是一种强一致性。 值得注
我的经验表明...... ofy().consistency(Consistency.STRONG).load().type(this.getEntityClass()).count() ...插入后
我需要使用一些唯一且一致的ID来索引数据,我尝试使用NSManagedObject的objectID,但是对于同一实体,它的objectID不断变化,有人知道这是否不一致吗? 最佳答案 除非您没有保存
官方文档是否在某处谈论 CloudKit 一致性?根据我的测试,它似乎是最终一致的——在写入后立即读取记录可能有效,也可能无效(返回空结果): CKDatabase *database = [[CKC
我有一个 FaunaDB,我想将其作为文档存储进行交互。我有一个 api: 从 FaunaDB 读取整个文档 根据对 api 的输入任意改变该数据 写回变异的同时保证数据没有被变异 如果尝试写入时读取
如果我不需要一致的状态或“严格”原子性,我会尝试了解何时使用数据库事务。 我没有某些银行风格要求,需要减少一列来抵消其他地方的增加。 我确实有某种形式的原子性,但只是为了“易于使用”,我想知道这是否足
我有一个包含多个 InnoDB 表的数据库,我想从中读取数据,然后将数据转储为 XML 格式。这样的 XML 将表示一个对象及其所有相关对象。 我不希望在读取过程中执行任何 INSERT(SELECT
所以我有一个排行榜,我每天使用以下查询有效地获取每个用户的分数: SELECT DATE(a.time) as time, a.userid, SUM(activity_weight) as weig
我正在尝试检查两个数据库之间的数据加载结果。不幸的是,我只能直接访问一个数据库 (MySQL),管理 MSSQL 的公司可以通过 API 将其公开给我们。 我想做的是检查行集中某些列的一致性。最初,我
我的类经常有一些属性,而其他对象的属性依赖于这些属性。定义和访问它们的最佳方式是什么?一个最小的例子应该可以解释我的问题。 假设我有一个定义圆的类: class Circle: def __i
1 基本场景 比如你有 N 个 cache 服务器(后面简称 cache ),那么如何将一个对象 object 映射到 N 个 cache 上呢,你很可能会采用类似下面的通用方法计算 o
假设我有两个集合,每个集合的值彼此独立,但每个都相互关联。他们是 photos和 users .用户和照片之间是一对多的关系。 非规范化数据的示例: users: { "id": "AABC",
我在 UIView 上有一个 UIButton。我想以编程方式确定显示 View 时在按钮内显示哪个图像。我已经重写了 UIView 中的 drawRect 方法并使用 setImage 来显示所需的
这里consistent request in Mongo我找到了如何在 java 代码中处理一致的请求。 DB db...; db.requestStart(); try { db.reque
目前,我正在使用 scipy 库中的 basshopping 来查找优化目标函数的最佳 x(其中 x 总共由 4 个因子组成)。当我让它运行几次时,每次运行都会给出不同的结果。有没有办法使结果更加一致
我有一个使用 android:layout_weight 作为标题间距的应用程序,但是当我在不同的屏幕尺寸上查看该应用程序时,间距会发生变化(与下面的行数据不对齐)。 我有 5 个 header ,但
当我的教授说“变量 1 和变量 2 应该处于一致状态”时,他的意思是什么? “处于一致状态”是什么意思? 最佳答案 这个措辞我听起来不太熟悉,但也许这就是教授的意图。我认为他的意思是变量已经初始化了。
我有 3 张 table : 模块: id_module | name -------------------- 1 users 2 roles .
我是一名优秀的程序员,十分优秀!