2

所以我试图动态加载我的域数据服务,其中表名是字符串......这是我到目前为止所得到的:通常我会像这样加载:

 theDomainDataService.Load(theDomainDataService.getUsersQuery());

所以我试图自动化哪个实体由字符串名称加载。

 String theVariableEntityName = "Users";
 Type t = theDomainDataService.GetType();
 MethodInfo stuff = t.GetMethod("Get" + theVariableEntityName + "Query");
 var theQuery = stuff.Invoke(theDomainDataService, null);
 theDomainDataService.Load((EntityQuery<MySite.Web.Models.User>)theQuery);
  ---------------------------------------------------------^ Problem

这实际上是正确加载我的 domainDataService,但我需要的是一种动态方式来推断 EntityQuery 的类型(没有明确声明它将成为用户),因为实际上它可以是任何东西。

我已经从 DomainDataService 类尝试过这个,但没有成功,它没有找到方法的“Set”或“Entry”。

    public List<object> void PopulateEntity(string theEntityName)
    {
        Type theEntity = Type.GetType("MySiteMaintenance.Web.Models." + theEntityName);
        using (var db = new DatingEntities()) 
        {                        
              IQueryable query = db.Set(theEntity);
              foreach (var item in query) 
              {
                  var entry = db.Entry(item);
              }
        }
    }

请记住,我只需要一个填充的实体(当我只有实体的名称时)填充客户端......所以我可以说

 DomainServiceClass theClass = new DomainServiceClass();
 theClass.Load(theClass.GetEntityNameQuery());

所以我可以引用适当加载的实体...... theClass.Entity(用户......问题等......)

4

1 回答 1

5

我仍然不确定我是否跟随,但是...

我的命名空间中有一个Post实体,我使用字符串中的实体类型名称Sandbox从我的DbContext实例中获取它以开头...

                // Get my entity type (if in same assembly, else you'll have to specify)
                Type postType = Type.GetType("Sandbox.Post");

                using (var db = new StackOverflowEntities()) {                        

                    // not required
                    db.Configuration.ProxyCreationEnabled = false;

                    IQueryable query = db.Set(postType);
                    foreach (var item in query) {

                        DbEntityEntry entry = db.Entry(item);

                    }
                }

这会导致基于实体类型字符串检索任何 DbSet。在项目 foreach 循环中的断点下方 - 显示值。

在此处输入图像描述

于 2013-01-05T20:12:58.003 回答