解决了Linq经常报一些莫名其妙的操作无效或者违反约束的错误

最近一段时间一直在用Linq,特别是用了Orcas之后提供了IDE支持顺手多了(在2005里面只能手工写,有语法错误看不出来)。但是有时候程序运行时总会出现一些奇怪的操作无效或者违反结束之类的错误,而且这种错误是整体性的,在一个DataContext当中,一旦发生一次错误。所有使用这个DataContext进行的写入(新增、删除、更新)都无法进行,当然select是可以进行的。

这种错误隐避性太大,往往是因为程序中的某一个操作数据库时的错误就会导致整个更新无法进行(即使是RejectChanges()也不能恢复到之前的状态),所以我必须得解决啊。在跟踪了无数次没有得到确切的原因之后,我初步断定是因为这个DataContext使用的Cache机制内部的原因。有可能是有BUG,也有可能是我对这套Cache机制还不够了解,用错误的模式来使用了。

回过头来看看自己的程序的架构(估且用这个词吧),嘿嘿,创建一个DC然后在各个需要使用到的地方传入这个对象,就象之前使用Connection对象一样。这有可能是最节约资源的方式吧!但既然有问题,我决定把这个“架构”改为每次操作之前重新生成一个DC对象。正好利用DC对象的IDBConnection参数的构造函数,也可以省去使用连接字符串每次都要创建连接对象的时间。修改了这个框架之后,错误完全消失了!

看来如果我打算长期使用Linq,得要花更多的时间去了解一下其内部Cache机制的原理啦!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值