Csharp/C#教程:首先通过将type作为参数传递,在Entity Framework DB中动态实例化Model对象分享


首先通过将type作为参数传递,在Entity Framework DB中动态实例化Model对象

需要通过将表名作为参数(在DB第一种方法中生成的模型并使用EF 6.0)动态创建entity framework生成的Model类的实例

喜欢,

// Input Param string tableName // Context always same DBContext dbContext= new DBContext(); //Need to create object query dynamically by passing //table name from front end as below IQueryable query = dbContext."tableName "; 

需要传递100多个表作为输入参数并且所有表的结构相同。

请帮忙。

你可以使用Dictionary 。 也许你想要这样的东西:

 // Input Param string tableName = "TblStudents"; Dictionary myDictionary = new Dictionary() { { "TblStudents", typeof(TblStudent) }, { "TblTeachers", typeof(TblTeacher) } }; // Context always same DBContext dbContext = new DBContext(); DbSet dbSet = dbContext.Set(myDictionary[tableName]); 

但是您不能使用任何LINQ扩展方法,因为它们是在generics类型IQueryable上定义的,但DbContext.Set的非generics重载返回非genericsDbSet 。 此类还实现了非genericsIQueryable 。 您可以在此处使用两种方法来使用LINQ方法:

  1. System.Linq.Dynamic添加到项目中(要安装System.Linq.Dynamic ,请在程序包管理器控制台中运行以下命令):

    Install-Package System.Linq.Dynamic

    然后你可以:

     var dbSet = dbContext.Set(myDictionary[tableName]).Where("Id = @a", 12); 
  2. 使用Find方法:

    上述就是C#学习教程:首先通过将type作为参数传递,在Entity Framework DB中动态实例化Model对象分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

     //But this returns a single instance of your type var dbSet = dbContext.Set(myDictionary[tableName]).Find(12); 

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/961484.html

(0)
上一篇 2021年11月26日
下一篇 2021年11月26日

精彩推荐