- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
作为我们当前数据库工作的一部分,我们正在研究处理更新数据库的过程。
反复提到的一点是处理系统值(value)与用户值(value);在我们的项目中,用户和系统值存储在一起。例如……
我们有一个模板列表。
1, <system template>
2, <system template>
3, <system template>
这些在应用程序中映射到枚举 (1, 2, 3)
然后一个用户进来并添加...
4, <user template>
...和...
5, <user template>
然后..我们发布升级..并作为我们升级脚本的一部分插入...
<new id> [6], <new system template>
THEN!!...我们在新系统模板中发现了一个错误,需要更新它...问题是怎么回事?我们无法使用 ID6 更新记录(因为我们可能将其插入为 9 或 999,因此我们必须使用其他机制来识别记录)
因此,我们为此找到了两种可能的解决方案。
我们只需从 5000(或其他一些值)开始用户 ID,并在 10000(或其他一些值)测试数据。这将允许我们修改系统值并测试它们直到下一个 ID 范围的下限。
优点...快速且易于实现,
缺点...如果我们没有选择足够大的范围,可能会用完值!
我们分别存储系统和用户数据,使用 GUID 作为 ID,并使用 View 合并两个列表。
优点...可扩展...没有数据库大小限制。
缺点.. 实现起来更复杂。 (多对一可更新 View 等)
我坚决支持第一个选项,但我正在寻找一些弹药来支持我!
有没有人对这些方法有任何想法,甚至是我们错过的方法?
最佳答案
我在使用 GUID 作为我的数据库 ID 时从未遇到过问题(性能或开发 - 包括 TDD 和单元测试),而且我已经处理过一些相当大的问题。看看here , here和 here如果您想了解更多有关使用 GUID(以及可能涉及的 GOTCHAS)作为主键的信息 - 但我不能高度推荐它,因为安全地移动数据和数据库同步变得像早上刷牙一样容易: -)
对于你上面的问题,我会推荐第三列(如果可能的话)来指示模板是基于用户还是基于系统,或者你至少可以在插入它们时为系统模板生成 GUID 并保留手头的列表,这样如果您需要更新模板,您可以在 DEV、UAT 和/或 PRODUCTION 数据库中定位相同的 GUID,而不必担心覆盖其他模板。第三列会派上用场,尽管可以随意选择所有系统或用户模板,而无需将它们分成两个表(恕我直言,这太过分了)。
希望对你有帮助
罗布
关于database - 默认数据库 ID;系统和用户值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9702/
出现在 python 2.7.8 中。 3.4.1 不会发生这种情况。 示例: >>> id(id) 140117478913736 >>> id(id) 140117478913736 >>> id
好吧,我对动态创建的控件的 ID 很困惑。 Public Class TestClass Inherits Panel Implements INamingContainer
我收到下面的错误,说有堆栈溢出。发生这种情况是因为带有 IN (id, id, id...id) 的 SQL 语句有大量参数。有没有什么办法解决这一问题?这是在我使用 Eclipse 的本地环境中发生
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
为什么 CPython(对其他 Python 实现一无所知)有以下行为? tuple1 = () tuple2 = ()
非常简单的问题:当我有一个持久对象时,它通常有一个名为 ID 的属性(对于抽象类)。 那么..命名约定是ID还是Id? 例如。 public int ID { get; set; } 或 public
知道为什么我会收到此错误,我已经尝试了所有命名约定(小写/大写) 我正在使用 Vaadin,这是我的代码片段: public class Usercontainer extends BeanI
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
我需要改变表的所有主键 UPDATE TODO SET id = id + 1 但我做不到(Demo 来自 Ahmad Al-Mutawa 的回答)描述了原因。主键不能这样改。 我也不能根据这是 sq
我正在尝试列出与用户相关的讨论列表。 想象一下,如果你愿意的话: posts -------------------------------------------------------------
我有一个表,其中包含一些具有自己的 ID 和共享 SKU key 的文章。我尝试使用左连接进行查询,并使用组结果获取从查询返回的所有 id。 我的数据结构是这样的: id - name -
在下表People中: id name 1 James 2 Yun 3 Ethan 如果我想找到最大 ID,我可以运行此查询 select max(id) id from People; 结果是
我正在产品页面上创建评论模块,其中显示垃圾评论选项,并显示 onclick 显示和隐藏弹出窗口。现在它在单个评论中工作正常但是当评论是两个时它同时打开两个因为类是相同的。现在这就是为什么我想要获取父
根据 REST 哲学,PUT操作应该(取自维基百科): PUT http://example.com/resources/142 Update the address member of the co
我想知道如何在使用 PHP 或 JavaScript 进行身份验证后从 Google Analytics 获取 Property Id、View Id 和 Account Id?因为我希望能够将它们存
我想使用所选按钮的 ID 进行删除。但我不知道如何从中获取/获取 id。我尝试了 this.id 但不起作用。 这是我创建按钮的地方: var deleteEmployer= document.cre
我有一个具有以下结构的表“表” ID LinkedWith 12 13 13 12 14 13 15 14 16
请不要在未阅读问题的情况下将问题标记为重复。我确实发布了一个类似的问题,但 STACKOVERFLOW 社区成员要求我单独重新发布修改后的问题,因为考虑到一个小而微妙的修改,解决方案要复杂得多。 假设
在 Android Studio 中,我创建了一个 Person.java 类。我使用Generate 创建了getter 和setter 以及构造函数。 这是我的 Person.java 类: pu
如何在 jQuery 中制作这样的东西: //这是显示的主体 ID //当我悬停 #hover-id 时,我希望 #principal-id 消失并更改 。但是当我将光标放在 #this-id 上时
我是一名优秀的程序员,十分优秀!