我有一个包含许多上传文件的应用程序。我正在尝试快速找到尚未与任何记录关联的孤立文件以进行删除以释放磁盘空间。
我已经创建了这种方法,但它让我的(可怜的)linq 窒息。
谁能看到我做错了什么??
public static IQueryable GetOrphanedFiles(int skip = 0, int take = 100)
{
using (var ctx = new CS3Entities())
{
var files = (from f in ctx.Files
select new
{
FileID = f.ID
});
var links = (from l in ctx.FileLinks
group l by l.FileID
into g
select new
{
FileID = g.Key
});
var orhpans = links.Where(f => files.Contains(f.FileID)); <-- dies here
return orhpans.Skip(skip).Take(take);
}
}