使用ASP MVC / Entity Framework中的通用数据类型进行搜索

时间:2013-01-22 21:04:35

标签: asp.net-mvc entity-framework

以下是我在使用Entity Framework构建的WCF服务参考中使用的代码。正如您所看到的,现在我一遍又一遍地使用相同的代码。是否有一种语法允许我用泛型或其他类似的方法替换实体,这样可以减少使用的代码量?

        var aI = (from AgentIdentification s in _db.AgentIdentification
                  where s.SymetraNumber == sNum
                  select s);

        foreach (var record in aI)
        {
            _db.AgentIdentification.DeleteObject(record);
        }

        _db.SaveChanges();

        var aG = (from Agent s in _db.Agent
                  where s.SymetraNumber == sNum
                  select s);

        foreach (var record in aG)
        {
            _db.Agent.DeleteObject(record);
        }

        _db.SaveChanges();

1 个答案:

答案 0 :(得分:1)

我相信这就是你想要的。

PerformChanges<YourDbObject, AgentIdentification>(x => x.AgentIdentification, sNum, _db);
PerformChanges<YourDbObject, Agent>(x => x.Agent, sNum, _db);

private void PerformChanges<DbType,TCollection>(Func<DbType,DbSet<TCollection>> FetchDbSetLambda, int sNum, DbType your_db)
        {
            var aI = (from s in FetchDbSetLambda(your_db)
                      where s.SymetraNumber == sNum
                      select s);

            foreach (var record in aI)
                FetchDbSetLambda(your_db).DeleteObject(record);
        }