1

我有一个包含许多上传文件的应用程序。我正在尝试快速找到尚未与任何记录关联的孤立文件以进行删除以释放磁盘空间。

我已经创建了这种方法,但它让我的(可怜的)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);
    }
}
4

1 回答 1

3

更改如下:

var orhpans = links.Where(f => files.Select(x => x.FileID).Contains(f.FileID));
于 2013-02-17T12:55:09.060 回答