加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 断开连接的LINQ更新:rowversion与带触发器的日期时间?

发布时间:2020-12-16 01:43:45 所属栏目:百科 来源:网络整理
导读:我们将LINQ to SQL和WCF用于新的中间层,我们使用数据传输对象来传递线路而不是使用实际的LINQ类.我将使用此处概述的一种或另一种方法 – Linq Table Attach() based on timestamp or row version – 以确保更新正常工作并且正确处理并发. 为了节省大量的阅读
我们将LINQ to SQL和WCF用于新的中间层,我们使用数据传输对象来传递线路而不是使用实际的LINQ类.我将使用此处概述的一种或另一种方法 – Linq Table Attach() based on timestamp or row version – 以确保更新正常工作并且正确处理并发.

为了节省大量的阅读时间,基本上你可以在表中使用timestamp / rowversion列,或者使用带有默认值和更新触发器的datetime列 – 无论哪种方式,它都会获得一个每次获取新生成值的列发生插入或更新,该列是LINQ用于检查并发的列.

我的问题是 – 哪一个更好?我们的许多表中已经有“UpdatedWhen”的日期时间列(但不是全部 – 不要问),但是会添加默认值和触发器,或者我们可以添加rowversion(我们必须使用现在的时间戳语法,因为我们仍然支持SQL2005一段时间)到每个表 – 我们正在修改数据库以使其工作,所以我想知道是否有性能差异或任何这两种选择之间需要注意的其他重要区别.我已经尝试过在网上搜索,但是到目前为止还没有运气.谢谢.

解决方法

我倾向于使用timestamp列进行并发检查.一个 – 触发器会对性能产生一些影响,两个 – 使用日期时间列,您将限制自己在SQL和C#中的DateTime列的精度.

MSDN:

datetime values are rounded to increments of .000,.003,or .007 seconds…

您可以查看SO: Is there any difference between DateTime in c# and DateTime in SQL server?和MSDN: datetime (Transact-SQL)以获取更多信息.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读