是否可以访问 IQueryable 后面的 DataContext 对象?
如果是,怎么做到的?
最佳答案
DataContext 特定于 LINQ to SQL,所以您大概是在谈论 LINQ to SQL 查询?如果是这样,则没有安全的方法来执行此操作 - 您必须诉诸黑客,例如使用反射来检索底层 DataQuery 对象的私有(private)“上下文”字段:
static DataContext GetContext (IQueryable q)
{
if (!q.GetType().FullName.StartsWith ("System.Data.Linq.DataQuery`1")) return null;
var field = q.GetType().GetField ("context", BindingFlags.NonPublic | BindingFlags.Instance);
if (field == null) return null;
return field.GetValue (q) as DataContext;
}
关于c# - 访问 IQueryable 后面的 DataContext,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3208439/