English 中文(简体)
实体框架小组By实体类型
原标题:EntityFramework GroupBy Entity Type

我有一个基地实体A和衍生实体:AA、AB、AC、AD

context.A.GroupBy(x => x.GetType()).Select(x => new { type=x.GetType(), count = x.Count() });

我当然会犯错:

LINQ to Entities does not recognize the method System.Type GetType() method, and this method cannot be translated into a store expression.

如何按类型对衍生实体进行分类?

问题回答

如果预定义了类型, 您可以使用 < a href=" http:// msdn.microsoft.com/ en- us/library/bb360913. aspx" rel = “ nofollow” > 数不胜数。

var acs = context.A.OfType<AC>().Count();

您需要在调用 GroupBy 之前, 需要将实体水化以内存 。 这样一来 x. GetType () 调用将由 LINQ 处理到对象, 而不是 LINQ 给实体。 请尝试这样做 :

context.A.ToList().GroupBy(x => x.GetType()).Select(x => new { type=x.Key, count = x.Count() });

我更改了它, 所以您在选择中调用 x. Key 而不是 x. GetType (), 否则您将会得到像 IGrouping<... & gt; 那样的分组类型 。





相关问题
Anyone feel like passing it forward?

I m the only developer in my company, and am getting along well as an autodidact, but I know I m missing out on the education one gets from working with and having code reviewed by more senior devs. ...

NSArray s, Primitive types and Boxing Oh My!

I m pretty new to the Objective-C world and I have a long history with .net/C# so naturally I m inclined to use my C# wits. Now here s the question: I feel really inclined to create some type of ...

C# Marshal / Pinvoke CBitmap?

I cannot figure out how to marshal a C++ CBitmap to a C# Bitmap or Image class. My import looks like this: [DllImport(@"test.dll", CharSet = CharSet.Unicode)] public static extern IntPtr ...

How to Use Ghostscript DLL to convert PDF to PDF/A

How to user GhostScript DLL to convert PDF to PDF/A. I know I kind of have to call the exported function of gsdll32.dll whose name is gsapi_init_with_args, but how do i pass the right arguments? BTW, ...

Linqy no matchy

Maybe it s something I m doing wrong. I m just learning Linq because I m bored. And so far so good. I made a little program and it basically just outputs all matches (foreach) into a label control. ...

热门标签