1

我在实体框架中有一个父/子表,我需要根据子主键从父级中选择一些行。

我写了这些代码:

List<int> s = (from all in DB.TbProfiles
                    where all.TbMaharat.Any(c => maharat.Contains(c.MaharatId))
                    select all.ProfileId).ToList();

但我发现 Linq2Entity 不支持“包含”,我必须使用“MultiSet”和 ESQL 命令。但我可以找到任何样本来做到这一点。

我这样写 ESQL 但它不起作用:

byte[] moshTypes = new byte[] { 1, 2, 3 };

        List<int> s =  DB.TbProfiles.Where("it.TbMaharat exists(Select 0 from TbMaharat as e where e.MaharatId IN MultiSet (" + string.Join(",", moshTypes) + "))")
            .Select(c=>c.ProfileId).ToList();

        return s;

谁能帮我?

4

1 回答 1

0

要使用IEnumerable<T>.Contains()方法,您必须使用ToList()or将表加载到内存中ToArray()。然而,这可能会导致巨大的内存成本,所以除非表非常小并且不会及时增长,否则不要这样做。方法有一个解决Contains方法:为每个值构建一个OR表达式,使Contains()方法变为DB.TbMaharat.Where(x=>x.MaharatId == 1 || x.MaharatId == 2 || x.MaharatId == 3). 请参阅 MSDN 线程以了解如何执行此操作:http ://social.msdn.microsoft.com/forums/en-US/adodotnetentityframework/thread/095745fe-dcf0-4142-b684-b7e4a1ab59f0/ 。

于 2011-11-14T12:54:55.307 回答