当数据库中的数据发生更改时,LINQ to SQL 不会更新

LINQ to SQL does not update when data has changed in database(当数据库中的数据发生更改时,LINQ to SQL 不会更新)
本文介绍了当数据库中的数据发生更改时,LINQ to SQL 不会更新的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有这个问题,在数据库上更新一个字段(比如表 MyTable 中的 Field3)后,MyTable.Field3(在 C# 中)仍然返回旧值.

I have this problem where after a field (say Field3 in table MyTable) is updated on the database, MyTable.Field3 (in C#) is still returning the old value.

我怀疑有一些缓存...?

I suspect there is some caching...?

我如何强制它:
从数据库中读取值?

更新 MyTable 类中的值?

How do I force it to:
Read the value from the database?
OR
Update the value in the MyTable class?

或者有什么我想念的吗?我是 LINQ 的新手

Or is there anything I miss? I am new to LINQ

提前致谢.

推荐答案

DataContext.Refresh(System.Data.Linq.RefreshMode.OverwriteCurrentValues, entity);

如果您想刷新整个实体集,最简单的方法可能是创建一个新的 DataContext 并重新查询所有内容.

If you want to refresh your entire entity set, the easiest way is probably to just create a new DataContext and requery for everything.

这篇关于当数据库中的数据发生更改时,LINQ to SQL 不会更新的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Multicast delegate weird behavior in C#?(C# 中的多播委托奇怪行为?)
Parameter count mismatch with Invoke?(参数计数与调用不匹配?)
How to store delegates in a List(如何将代表存储在列表中)
How delegates work (in the background)?(代表如何工作(在后台)?)
C# Asynchronous call without EndInvoke?(没有 EndInvoke 的 C# 异步调用?)
Delegate.CreateDelegate() and generics: Error binding to target method(Delegate.CreateDelegate() 和泛型:错误绑定到目标方法)