C# 协方差问题

C# 协方差问题,c#,linq,linq-to-sql,c#-3.0,covariance,C#,Linq,Linq To Sql,C# 3.0,Covariance,我有一个linq到sql生成的域实体,我将其转换到适当的接口,如下所示: public IEnumerable<IApplication> GetApplications() { using (var dc = new LqDev202DataContext()) { return dc.ZApplications.Cast<IApplication>().ToList(); } }

我有一个linq到sql生成的域实体,我将其转换到适当的接口,如下所示:

public IEnumerable<IApplication> GetApplications()
    {
        using (var dc = new LqDev202DataContext())
        {
            return dc.ZApplications.Cast<IApplication>().ToList();
        }
    }
但是,我重命名了linq to sql表,没有涉及我的分部类,代码仍在编译中

列表中的元素数量正确,但它们都为空


我是否需要编写一个助手方法来确保这一点,或者在.net 3.5中是否有编译时安全的简单内置方法来实现这一点?

如果需要,您还可以使用此方法进行转换转换转换:

public static IEnumerable<TDest> CastAll<TItem, TDest>(this IEnumerable<TItem> items)
{
 var p = Expression.Parameter(typeof(TItem), "i");
 var c = Expression.Convert(p, typeof(TDest));
 var ex = Expression.Lambda<Func<TItem, TDest>>(c, p).Compile();

 foreach (var item in items)
 {
    yield return ex(item);
 }
}

我不认为这是一个协方差问题。我想这是由重命名引起的LINQ到SQL问题。