首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何将所有类型的DbSets赋给一个变量

如何将所有类型的DbSets赋给一个变量
EN

Stack Overflow用户
提问于 2017-09-23 00:11:53
回答 1查看 289关注 0票数 1

有没有可能创建一个变量,将所有类型的DbSets赋值给该变量,然后对该变量进行所有CRUD操作,例如删除()方法?我尝试过使用object类型的DbSet,但是我得到了一个编译错误。

我的代码:

代码语言:javascript
运行
复制
DbSet<object> table = null; 

switch (type)
{
    case "Room": table = context.Rooms; break;
    case "Subject": table = context.Subjects; break;
    // table = context.Rooms/Subjects - error
}
EN

回答 1

Stack Overflow用户

发布于 2017-09-23 04:45:20

实体框架已经有了一个非泛型DbSetDbSet<object>。你所要做的就是强制转换它,因为DbSet有一个隐式运算符。

代码语言:javascript
运行
复制
DbSet table = null;

switch (type) {
   case "Room": table = (DbSet)context.Rooms; break;
   case "Subject": table = (DbSet)context.Subjects; break;
}

在你有了DbSet之后,如果你愿意,你可以得到通用版本。

代码语言:javascript
运行
复制
var rooms = table.Cast<Room>()

更新:(针对EFCore)您是否考虑过仅依赖DbContext来实现此目的?您在EF Core中的DbContext继承类已经具有与DbSet<T>方法匹配的泛型和非泛型方法,以实现您正在尝试实现的相同目标。

下面是它支持的方法列表:

  • Add(Object)
  • Add(TEntity)
  • AddRange(IEnumerable)
  • AddRange(Object[])
  • Find(Type,Object[])
  • Find(Object[])
  • Remove(Object)
  • Remove(TEntity)
  • etc...

为什么要重新发明这个框架

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46369007

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档