如何解决检索到之后,在实体实例上设置DataContext
|| 我正在尝试找到一种方法来使Entities中的DataContext可用。 我想做这样的事情:partial public class MyEntity
public DataContext as MyDataContext
private sub OnLoaded()
Me.DataContext = <the context that retrieved this instance>
end sub
end class
首先,可以这样做吗?
其次,假设我不会将此实体与任何其他DataContext一起使用,那么这样做会不会有任何危险或陷阱?
这是我目前的做法:
partial public class MyDataContext
public function GetMyEntity(byval id as integer) as MyEntity
dim o = MyEntities.SingleOrDefault(function(e) e.id = id)
if o isnot nothing then o.DataContext = Me
return o
end function
end class
解决方法
您可以在DataContext上使用单例模式,但是您将需要对其进行某种生命周期管理,因为将其保留很长的时间是不好的。 (请求结束可能会处理)
C#中的示例,但希望您能理解。
public class MyDataContext
{
public static MyDataContext Current
{
get
{
MyDataContext context = (MyDataContext)HttpContext.Current.Items[\"Context\"];
if(context == null)
{
context = new MyDataContext();
HttpContext.Current.Items[\"Context\"] = context;
}
return context;
}
}
}
public class MyEntity
{
public MyDataContext DataContext
{
get{ return MyDataContext.Current;}
}
}
在Global.asax中,您可以挂接事件Application_EndRequest
并调用MyDataContext.Current.Dispose();
来手动处理上下文,而不必等待GC进行处理。
,尽管您没有指定真正的原因,但只是MSDN的一个旁注:
通常,一个“ 5”实例是
旨在持续使用一个“
工作”,但您的应用程序定义了
这个学期。 DataContext
是
轻巧且价格不贵
创建。典型的LINQ to SQL
应用程序创建DataContext
方法范围内或作为
短期课程的成员
表示相关的逻辑集合
数据库操作。
还有一个:
不要尝试重用
DataContext
。各DataContext
维持状态(包括身份)
缓存)用于一个特定的编辑/查询
会议。基于获取新实例
根据数据库的当前状态,
使用新的DataContext
。
最后,
...任何实例成员都不是
保证是线程安全的。
但是,在某些情况下,半永久性解决方案还是很有帮助的。看看Rick Strachl的文章:SQL DataContext生命周期管理的Linq。 “五”管理的方法有很多种。在它们之上-创建每个业务对象DataContext正是您所需要的。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。