gpt4 book ai didi

c# - 枚举整个 LinqToSql 对象

转载 作者:太空宇宙 更新时间:2023-11-03 15:28:22 25 4
gpt4 key购买 nike

我的数据库包含 100 多个高度规范化的表,并且数据不会经常更改。我正在使用 LinqToSql 并封装一些简单的调试和查询,这样就不需要理解整个数据库设计来获取数据。我试图在不真正关心性能的情况下实现快速原型(prototype)制作。

有没有一种简单的方法可以将整个 LinqToSql 对象枚举到内存中的只读容器中?如果存在类似的东西,来自某个时间点的缓存也可以。它会变得很大,我完全意识到这一点。

using (Context db = new Context())
{
var a = db.Table1s.AsEnumerable();
var b = db.Table2s.AsEnumerable();

var q = a.Where(x => x.SomeComplexMethod())
.Join(b...)
}

我希望能够做这样的事情:

using (Context db = new Context())
{
var enumerated = db.Materialize();

var q = enumerated.Table1s()
.Where(x => x.SomeComplexMethod())
.Join(enumerated.Table2s...)
}

最佳答案

我能想到的唯一方法是反射,使用这样的扩展方法,您将能够一次性获取所有对象:

public static class ContextExtensions
{
public static IEnumerable<IQueryable> GetAllDbSets(this DbContext context)
{
return context.GetType()
.GetProperties()
.Where(p => p.PropertyType.IsGenericType
&& p.PropertyType.GetGenericTypeDefinition() == typeof(DbSet<>))
.Select(p => (IQueryable)p.GetValue(context));
}
}

然后你可以像这样使用它:

using (var context = new ApplicationDbContext())
{
var allTables = context.GetAllDbSets();

var allTablesInMemory = context.GetAllDbSets()
.Select(q => Enumerable.ToArray((dynamic)q))
.ToArray();

var allValuesInArray = context.GetAllDbSets()
.SelectMany<dynamic,dynamic>(q => Enumerable.ToArray(q))
.ToArray();
}

但在任何情况下,它都不应被视为使用数据库的好方法。

关于c# - 枚举整个 LinqToSql 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34469040/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com