- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近一直在阅读有关 LINQ 的资料以开始实现它,关于它如何生成更新查询这一点特别困扰我。
使用 SQLMetal 或对象关系设计器自动创建实体代码,显然所有表的所有字段都将获得属性 UpdateCheck.Always,这意味着对于每个 UPDATE 和 DELETE 查询,我将获得像这样的 SQL 语句:
UPDATE table SET a = 'a' WHERE a='x' AND b='x' ... AND z='x', ad infinitum
现在,称我为纯粹主义者,但这对我来说似乎极其低效,而且无论如何感觉这都是个坏主意,即使它并非低效。我知道提取将通过聚簇主键完成,所以这并不慢,但 SQL 仍然需要检查之后的每个字段以确保它匹配。
诚然,在一些非常敏感的应用程序中,像这样的东西可能很有用,但对于典型的网络应用程序(想想 Stack Overflow),UpdateCheck.WhenChanged 似乎是一个更合适的默认值,并且我个人更喜欢 UpdateCheck.Never,因为 LINQ 只会更新实际更改的字段,而不是所有字段,并且在大多数实际情况下,第二个人编辑的内容无论如何都会获胜。
这确实意味着如果两个人设法在读取该行和触发 UPDATE 之间的短时间内编辑同一行的同一字段,那么将不会触发将发现的冲突。但实际上这是非常罕见的情况。当两个人更改相同的东西时我们可能要防止的一件事不会被这个捕获,因为他们不会在完全相同的时间点击提交,所以在第二个 DataContext 时不会发生冲突读取和更新记录(除非在显示页面时 DataContext 保持打开状态并存储在 Session 中,或者其他类似的非常糟糕的想法)。
但是,尽管这种情况很少见,但如果发生这种情况,我真的不想时不时地在我的代码中遇到异常。
所以我的第一个问题是,我相信这一点是不是错了? (同样,对于“典型”网络应用程序,不适用于银行应用程序)我是否遗漏了为什么将 UpdateCheck.Always 作为默认值是一个明智的想法的原因?
我的第二个问题是,我可以文明地改变这个吗?有没有办法告诉 SQLMetal 或 ORD 要设置哪个 UpdateCheck 属性?
我试图避免我必须记住运行一个工具的情况,我必须使它采用一些正则表达式并直接编辑文件中的所有属性,因为很明显在某些时候我们会运行SQLMetal 在更新数据库后,我们不会运行这个工具,我们所有的代码都会以非常微妙的方式中断,而我们在开发中测试时可能不会发现。
有什么建议吗?
war 故事非常受欢迎,我很乐意从其他人的经验中学习。
非常感谢!
最佳答案
好吧,回答第一个问题 - 我同意你的看法。我不是这种“内置”乐观并发的忠实拥护者,尤其是当您有时间戳列或更新发生后不能保证相同的任何字段时。
为了解决第二个问题——我不知道有什么方法可以覆盖 SqlMetal 的默认方法(UpdateCheck = Always),我们最终编写了一个工具来为适当的列设置 UpdateCheck = Never。我们正在使用批处理文件调用 SqlMetal,然后运行该工具)。
哦,虽然我想到了 - 发现 SqlMetal 还对关系建模以将外键设置为 null 而不是“Delete On Null”(特别是对于连接表)也是一种享受。我们也必须使用相同的后生成工具来适本地设置这些。
关于LINQ 冲突检测 : Setting UpdateCheck attribute,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/685930/
关于 this页面,我看到以下代码: if ((attributes & FileAttributes.Hidden) == FileAttributes.Hidden) 但我不明白为什么会变成这样。
函数pthread_mutex_init允许您指定指向属性的指针。但是我还没有找到关于pthread属性是什么的很好的解释。我一直只是提供NULL。这个论点有用吗? 该文档,对于那些忘记它的人: PT
我们有一个 xml 节点“item”,其属性为“style”,即“Header1”。但是,这种风格可以改变。我们有一个名为 Header1 的属性集,它定义了它在 PDF 中的外观,通过 xsl:fo
我的任务是在用户点击它时从输入框中删除占位符并使标签可见。如果用户未在其中再次填写任何内容,请放回占位符并使标签不可见。 我可以隐藏它但不能重新分配它。我试过 element.setAttribute
我从文章中编写代码,并且有: public IActionResult Create([Bind(Include="Imie,Nazwisko,Stanowisko,Wiek")] Pracownik
你能给我解释一下以下属性吗? 1) [MonoTouch.Foundation.Register("SomeClass")] 这个属性是否只用于向IB注册类?以编程方式扩展 iOS 类时是否必须使用此
我正在编写一个 C++ 程序,在调试时我在执行以下函数: int CClass::do_something() { ... // I've put a breakpoint here } 我的 C
我已经在 polymer 0.5 中构建了我的应用程序。 现在我已经将它更新到 polymer 1.0。 对于响应式布局,我使用了一个布局属性,它使用 Polymer 0.5 中布局属性的自定义逻辑。
我是使用 Jade 的新手——到目前为止它很棒。 但是我需要发生的一件事是具有“itemscope”属性的元素: 我的 Jade 符是: header(itemscope, itemtype='ht
我正在研究一个厨师实现,有时在过去的地方使用了 attribute.set,attribute.default 会这样做。为了解决这个问题,我对 Chef 属性优先范式非常熟悉。我知道“正常”属性(使
我经常看到html data-attribute (s) 将特定值/参数添加到 html 元素,例如使用它们将按钮“链接”到要打开的模式对话框等的 Bootstrap。 现在,我看到一个几乎著名的
假设如下: def create_new_salt self.salt = self.object_id.to_s + rand.to_s end 为什么使用“ self ”更好。而不是实例变量“
根据我的理解,Backbone.js 模型的属性应该通过以下方式声明为有点私有(private)的成员变量 this.set({ attributeName: attributeValue }) //
我有一个看起来像下面的XML文档: ... ... ... ...
我正在实现一个 JSF 组件,需要有条件地添加一些属性。这个问题类似于之前的 JSF: p:dataTable with f:attribute results in "argument type m
我正在尝试将应用程序发布到 Android 电子市场,但出现以下错误: W/ResourceType(16964): No known package when getting value for r
抱歉这么具体的应用程序,但我注意到另一篇关于 Maya 开发的回答很好的帖子。 我刚刚为 Maya 编写了一个插件节点。它只是根据湍流函数杀死一堆粒子。湍流由许多可在属性编辑器中调整的属性驱动。 在属
我在 html 元素中的数据属性为 Update .它具有数据属性的 bool 值。 跟下面的元素Update有什么区别吗?因为数据属性用双引号引起来。 html是否支持 bool 值? 最佳答案 b
我正在尝试为企业库 5.0 的异常处理 block 创建自定义异常处理程序。据我了解,我需要使用属性开始上课“[ConfigurationElementType(typeof(CustomHandle
我找不到这两个选择器之间的区别。两者似乎都做同样的事情,即根据包含给定字符串的特定属性值选择标签。 对于 [attribute~=value] :http://www.w3schools.com/cs
我是一名优秀的程序员,十分优秀!