用户登录
用户注册

分享至

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

  • 作者: 站得更高尿的更远
  • 来源: 51数据库
  • 2022-12-08

问题描述

我有这个问题,在数据库上更新一个字段(比如表 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.

软件
前端设计
程序设计
Java相关