{"id":36,"date":"2013-03-06T10:07:00","date_gmt":"2013-03-06T04:37:00","guid":{"rendered":"https:\/\/www.inogic.com\/blog\/?p=36"},"modified":"2013-03-06T10:07:00","modified_gmt":"2013-03-06T04:37:00","slug":"aggregate-and-grouping-functions-using-linq-in-crm","status":"publish","type":"post","link":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/","title":{"rendered":"Aggregate and Grouping functions using LINQ in CRM"},"content":{"rendered":"<div dir=\"ltr\" trbidi=\"on\"><span><\/span><\/p>\n<div><span><span>As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &#038; aggregates.<\/p>\n<p><\/span><\/span><\/div>\n<p><span> <\/span><\/p>\n<div><span><span>FetchXML supports all the features of QueryExpression including grouping &#038; aggregates. Queries here are built as XML statements.<\/p>\n<p><\/span><\/span><\/div>\n<p><span> <\/span><\/p>\n<div><span><span>LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression and hence it is limited to the features of QueryExppression<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><a href=\"http:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png\" imageanchor=\"1\"><span><img decoding=\"async\" border=\"0\" height=\"130\" src=\"http:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png\" width=\"400\"><\/span><\/a><\/div>\n<p><span><\/span><br \/><span><\/span><\/p>\n<div><span><span>The <b>QueryExpression<\/b>class supports complex queries.<\/p>\n<p><\/span><\/span><\/div>\n<p><span><span>The <b>QueryByAttribute<\/b> class is a simple means to search for entities where attributes matches specified values.<\/p>\n<p><\/span><\/span><br \/><span><\/span><br \/><span><span>When using LINQ, it returns IQueryable<Entity><entity><entity> which is not a collection &#038; hence we can\u2019t do group-by or aggregate.<\/p>\n<p><\/entity><\/entity><\/span><\/span><br \/><span><\/span><br \/><span>IQueryable<Entity> queryDemo = from a in orgServiceContext.AccountSet<\/span><\/p>\n<p><span>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <span>where a.Address1_City.Contains(&#8220;a&#8221;)<\/span><\/span><\/p>\n<div><span>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 select a;<\/span><\/p>\n<p><span>\u00a0<\/span><\/p>\n<\/div>\n<div><span><\/span>\u00a0<\/div>\n<div><b><span><span>However, LINQ supports group by in following way.<\/p>\n<p><\/span><\/span><\/b><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span> Write a simple LINQ Query<\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>var lnqQuery = from o in orgServiceContext.OpportunitySet<\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span>where o.EstimatedValue.Value >= 10000<\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>select new<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>\u00a0\u00a0 {<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span>OpportunityTopic = o.Name,<\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>PotentialCustomer = o.CustomerId,<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span> Rating = o.OpportunityRatingCode<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span> };<\/span><\/span><br \/><span><span><\/p>\n<p><\/span><\/span>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span> In another query pass your created query as a list. You can either do a ToList() or you can make your own List like List<Groups> estList = new List<Groups>() where Groups is your custom class with set &#038; get. <\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span> <\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>Here, we are using ToList() &#038; grouping the collection by Rating.<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>var lnqQuery2 = (from f in lnqQuery.ToList()<\/p>\n<p><\/span><\/span><br \/><span><\/span>\u00a0<\/div>\n<div><span><span> \/\/Pass the lnqQuery as a list using ToList() &#038; then group by<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span> group f by f.Rating into queryGrp<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>  let first = queryGrp.First()<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span> \/\/selecting only the first record of all grouped record<\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>select new<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span> {<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span> Name = first.OpportunityTopic,<\/span><\/span><br \/><span><span><\/p>\n<p><\/span><\/span>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span> Rating = first.Rating.Value<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span> });<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span> Now if we want to retrieve all the records from the Query Group, then we can simply create a list of query Group using ToList() &#038; iterate through it as shown in below example<\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span> var lnqQuery2 = (from f in lnqQuery.ToList()<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span> \/\/Pass the lnqQuery as a list using ToList() &#038; then group by<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>group f by f.Rating into queryGrp<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span> \/\/Make a list of queryGrp using ToList()<\/span><\/span><br \/><span><span><\/p>\n<p><\/span><\/span>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>select queryGrp.ToList());<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>   \/\/Create a DataTable<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>DataTable table = new DataTable();<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span>\/\/Add some columns<\/span><\/p>\n<p>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>table.Columns.Add(&#8220;Topic&#8221;);<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>table.Columns.Add(&#8220;Cust&#8221;);<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>table.Columns.Add(&#8220;Rating&#8221;);<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>foreach (var e1 in lnqQuery2)<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>{<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span>\/\/iterate through each record grouped with rating<\/span><\/p>\n<p>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>foreach (var e2 in e1)<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>{<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span>\/\/iterate through each individual record that belongs in a rating<\/span><br \/><span><\/span><\/p>\n<p>\u00a0<\/p><\/div>\n<p><span><\/span><\/p>\n<div><span><span>DataRow dataRow = table.NewRow();<\/p>\n<p><\/span><\/span><br \/><span><\/span>\u00a0<\/div>\n<div><span><span>dataRow[&#8220;Topic&#8221;] = e2.OpportunityTopic;<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span>dataRow[&#8220;Cust&#8221;] = e2.PotentialCustomer.Name;<\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>dataRow[&#8220;Rating&#8221;] = e2.Rating;<\/p>\n<p><\/span><\/span><br \/>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span>table.Rows.Add(dataRow);<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>\u00a0}<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>}<\/p>\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span>\/\/here you have your list in your dataGridView<\/span><\/p>\n<p>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span>dataGridView1.DataSource = table;<\/span><\/p>\n<p><span><\/span><\/p>\n<p>\u00a0<\/div>\n<p><span><\/span><\/p>\n<div><span><span><b>Note-<\/b> Here we are just showing the rating value. You can get the rating by using FormattedValues[&#8220;opportunityratingcode&#8221;]\n<p><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><span>For more details you can visit <\/span><span><a href=\"http:\/\/msdn.microsoft.com\/en-in\/library\/gg334607.aspx\" target=\"_blank\" rel=\"noopener noreferrer\">here<\/a><\/span><\/span><\/div>\n<p><span><\/span><\/p>\n<div><span><\/span><br \/><span><span>Hope this article helps!<span><\/p>\n<p><\/span><\/span><\/span><\/div>\n<p><span>\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><\/p>\n<div><span>\u00a0<\/span><\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &#038; aggregates. FetchXML supports all the features of QueryExpression including grouping &#038; aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression\u2026 <span class=\"read-more\"><a href=\"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/\">Read More: Aggregate and Grouping functions using LINQ in CRM &raquo;<\/a><\/span><\/p>\n","protected":false},"author":13,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[19],"tags":[122,795,876,992,1392],"class_list":["post-36","post","type-post","status-publish","format-standard","hentry","category-dynamics-crm","tag-aggregate","tag-fetchxml","tag-grouping","tag-linq","tag-queryexpression"],"aioseo_notices":[],"aioseo_head":"\n\t\t<!-- All in One SEO 4.9.8 - aioseo.com -->\n\t<meta name=\"description\" content=\"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &amp; aggregates. FetchXML supports all the features of QueryExpression including grouping &amp; aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression\" \/>\n\t<meta name=\"robots\" content=\"max-image-preview:large\" \/>\n\t<meta name=\"author\" content=\"Inogic\"\/>\n\t<link rel=\"canonical\" href=\"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/\" \/>\n\t<meta name=\"generator\" content=\"All in One SEO (AIOSEO) 4.9.8\" \/>\n\t\t<meta property=\"og:locale\" content=\"en_US\" \/>\n\t\t<meta property=\"og:site_name\" content=\"Microsoft Dynamics 365 CRM Tips and Tricks - By Inogic\" \/>\n\t\t<meta property=\"og:type\" content=\"article\" \/>\n\t\t<meta property=\"og:title\" content=\"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks\" \/>\n\t\t<meta property=\"og:description\" content=\"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &amp; aggregates. FetchXML supports all the features of QueryExpression including grouping &amp; aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression\" \/>\n\t\t<meta property=\"og:url\" content=\"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/\" \/>\n\t\t<meta property=\"og:image\" content=\"https:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png\" \/>\n\t\t<meta property=\"og:image:secure_url\" content=\"https:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png\" \/>\n\t\t<meta property=\"article:published_time\" content=\"2013-03-06T04:37:00+00:00\" \/>\n\t\t<meta property=\"article:modified_time\" content=\"2013-03-06T04:37:00+00:00\" \/>\n\t\t<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/inogicindia\" \/>\n\t\t<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n\t\t<meta name=\"twitter:site\" content=\"@inogic\" \/>\n\t\t<meta name=\"twitter:title\" content=\"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks\" \/>\n\t\t<meta name=\"twitter:description\" content=\"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &amp; aggregates. FetchXML supports all the features of QueryExpression including grouping &amp; aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression\" \/>\n\t\t<meta name=\"twitter:creator\" content=\"@inogic\" \/>\n\t\t<meta name=\"twitter:image\" content=\"http:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png\" \/>\n\t\t<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t\t<meta name=\"twitter:data1\" content=\"Inogic\" \/>\n\t\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n\t\t<script type=\"application\/ld+json\" class=\"aioseo-schema\">\n\t\t\t{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"BlogPosting\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#blogposting\",\"name\":\"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks\",\"headline\":\"Aggregate and Grouping functions using LINQ in CRM\",\"author\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/author\\\/inogic-2\\\/#author\"},\"publisher\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/#organization\"},\"image\":{\"@type\":\"ImageObject\",\"url\":\"http:\\\/\\\/1.bp.blogspot.com\\\/-4phDc0Tyogs\\\/UTb1FTaeu9I\\\/AAAAAAAABn4\\\/W5r2h90tlII\\\/s1600\\\/new.png\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#articleImage\"},\"datePublished\":\"2013-03-06T10:07:00+05:30\",\"dateModified\":\"2013-03-06T10:07:00+05:30\",\"inLanguage\":\"en-US\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#webpage\"},\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#webpage\"},\"articleSection\":\"Dynamics CRM, aggregate, FetchXML, grouping, LINQ, queryexpression\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#breadcrumblist\",\"itemListElement\":[{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog#listItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.inogic.com\\\/blog\",\"nextItem\":{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/category\\\/dynamics-crm\\\/#listItem\",\"name\":\"Dynamics CRM\"}},{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/category\\\/dynamics-crm\\\/#listItem\",\"position\":2,\"name\":\"Dynamics CRM\",\"item\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/category\\\/dynamics-crm\\\/\",\"nextItem\":{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#listItem\",\"name\":\"Aggregate and Grouping functions using LINQ in CRM\"},\"previousItem\":{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog#listItem\",\"name\":\"Home\"}},{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#listItem\",\"position\":3,\"name\":\"Aggregate and Grouping functions using LINQ in CRM\",\"previousItem\":{\"@type\":\"ListItem\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/category\\\/dynamics-crm\\\/#listItem\",\"name\":\"Dynamics CRM\"}}]},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/#organization\",\"name\":\"Microsoft Dynamics 365 CRM Tips and Tricks\",\"description\":\"By Inogic\",\"url\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"url\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/wp-content\\\/uploads\\\/2023\\\/02\\\/inogic-logo.png\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#organizationLogo\",\"width\":1000,\"height\":325,\"caption\":\"inogic logo\"},\"image\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#organizationLogo\"},\"sameAs\":[\"https:\\\/\\\/www.facebook.com\\\/inogicindia\",\"https:\\\/\\\/twitter.com\\\/inogic\",\"https:\\\/\\\/www.instagram.com\\\/inogicindia\\\/\",\"https:\\\/\\\/www.youtube.com\\\/channel\\\/UCM4V7ousgLSu1hbOEv4DUuQ\",\"https:\\\/\\\/www.linkedin.com\\\/company\\\/inogicindia\"]},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/author\\\/inogic-2\\\/#author\",\"url\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/author\\\/inogic-2\\\/\",\"name\":\"Inogic\",\"image\":{\"@type\":\"ImageObject\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#authorImage\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/839d9ae7d2b941d2d09e91df322267a429821f2ce5494302b53bd5ca3679f1a0?s=96&d=mm&r=g\",\"width\":96,\"height\":96,\"caption\":\"Inogic\"}},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#webpage\",\"url\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/\",\"name\":\"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks\",\"description\":\"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping & aggregates. FetchXML supports all the features of QueryExpression including grouping & aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression\",\"inLanguage\":\"en-US\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/#website\"},\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/2013\\\/03\\\/aggregate-and-grouping-functions-using-linq-in-crm\\\/#breadcrumblist\"},\"author\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/author\\\/inogic-2\\\/#author\"},\"creator\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/author\\\/inogic-2\\\/#author\"},\"datePublished\":\"2013-03-06T10:07:00+05:30\",\"dateModified\":\"2013-03-06T10:07:00+05:30\"},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/\",\"name\":\"Microsoft Dynamics 365 CRM Tips and Tricks\",\"alternateName\":\"Inogic\",\"description\":\"By Inogic\",\"inLanguage\":\"en-US\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.inogic.com\\\/blog\\\/#organization\"}}]}\n\t\t<\/script>\n\t\t<!-- All in One SEO -->\n\n","aioseo_head_json":{"title":"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks","description":"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping & aggregates. FetchXML supports all the features of QueryExpression including grouping & aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression","canonical_url":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/","robots":"max-image-preview:large","keywords":"","webmasterTools":{"miscellaneous":""},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"BlogPosting","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#blogposting","name":"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks","headline":"Aggregate and Grouping functions using LINQ in CRM","author":{"@id":"https:\/\/www.inogic.com\/blog\/author\/inogic-2\/#author"},"publisher":{"@id":"https:\/\/www.inogic.com\/blog\/#organization"},"image":{"@type":"ImageObject","url":"http:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#articleImage"},"datePublished":"2013-03-06T10:07:00+05:30","dateModified":"2013-03-06T10:07:00+05:30","inLanguage":"en-US","mainEntityOfPage":{"@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#webpage"},"isPartOf":{"@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#webpage"},"articleSection":"Dynamics CRM, aggregate, FetchXML, grouping, LINQ, queryexpression"},{"@type":"BreadcrumbList","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#breadcrumblist","itemListElement":[{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog#listItem","position":1,"name":"Home","item":"https:\/\/www.inogic.com\/blog","nextItem":{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog\/category\/dynamics-crm\/#listItem","name":"Dynamics CRM"}},{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog\/category\/dynamics-crm\/#listItem","position":2,"name":"Dynamics CRM","item":"https:\/\/www.inogic.com\/blog\/category\/dynamics-crm\/","nextItem":{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#listItem","name":"Aggregate and Grouping functions using LINQ in CRM"},"previousItem":{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog#listItem","name":"Home"}},{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#listItem","position":3,"name":"Aggregate and Grouping functions using LINQ in CRM","previousItem":{"@type":"ListItem","@id":"https:\/\/www.inogic.com\/blog\/category\/dynamics-crm\/#listItem","name":"Dynamics CRM"}}]},{"@type":"Organization","@id":"https:\/\/www.inogic.com\/blog\/#organization","name":"Microsoft Dynamics 365 CRM Tips and Tricks","description":"By Inogic","url":"https:\/\/www.inogic.com\/blog\/","logo":{"@type":"ImageObject","url":"https:\/\/www.inogic.com\/blog\/wp-content\/uploads\/2023\/02\/inogic-logo.png","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#organizationLogo","width":1000,"height":325,"caption":"inogic logo"},"image":{"@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#organizationLogo"},"sameAs":["https:\/\/www.facebook.com\/inogicindia","https:\/\/twitter.com\/inogic","https:\/\/www.instagram.com\/inogicindia\/","https:\/\/www.youtube.com\/channel\/UCM4V7ousgLSu1hbOEv4DUuQ","https:\/\/www.linkedin.com\/company\/inogicindia"]},{"@type":"Person","@id":"https:\/\/www.inogic.com\/blog\/author\/inogic-2\/#author","url":"https:\/\/www.inogic.com\/blog\/author\/inogic-2\/","name":"Inogic","image":{"@type":"ImageObject","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#authorImage","url":"https:\/\/secure.gravatar.com\/avatar\/839d9ae7d2b941d2d09e91df322267a429821f2ce5494302b53bd5ca3679f1a0?s=96&d=mm&r=g","width":96,"height":96,"caption":"Inogic"}},{"@type":"WebPage","@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#webpage","url":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/","name":"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks","description":"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping & aggregates. FetchXML supports all the features of QueryExpression including grouping & aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression","inLanguage":"en-US","isPartOf":{"@id":"https:\/\/www.inogic.com\/blog\/#website"},"breadcrumb":{"@id":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/#breadcrumblist"},"author":{"@id":"https:\/\/www.inogic.com\/blog\/author\/inogic-2\/#author"},"creator":{"@id":"https:\/\/www.inogic.com\/blog\/author\/inogic-2\/#author"},"datePublished":"2013-03-06T10:07:00+05:30","dateModified":"2013-03-06T10:07:00+05:30"},{"@type":"WebSite","@id":"https:\/\/www.inogic.com\/blog\/#website","url":"https:\/\/www.inogic.com\/blog\/","name":"Microsoft Dynamics 365 CRM Tips and Tricks","alternateName":"Inogic","description":"By Inogic","inLanguage":"en-US","publisher":{"@id":"https:\/\/www.inogic.com\/blog\/#organization"}}]},"og:locale":"en_US","og:site_name":"Microsoft Dynamics 365 CRM Tips and Tricks - By Inogic","og:type":"article","og:title":"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks","og:description":"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &amp; aggregates. FetchXML supports all the features of QueryExpression including grouping &amp; aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression","og:url":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/","og:image":"https:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png","og:image:secure_url":"https:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png","article:published_time":"2013-03-06T04:37:00+00:00","article:modified_time":"2013-03-06T04:37:00+00:00","article:publisher":"https:\/\/www.facebook.com\/inogicindia","twitter:card":"summary_large_image","twitter:site":"@inogic","twitter:title":"Aggregate and Grouping functions using LINQ in CRM - Microsoft Dynamics 365 CRM Tips and Tricks","twitter:description":"As you know, QueryExpression are built as an Object Model. They support all the features of FetchXML except for grouping &amp; aggregates. FetchXML supports all the features of QueryExpression including grouping &amp; aggregates. Queries here are built as XML statements. LINQ queries are built using standard language similar to SQL, but internally it uses QueryExpression","twitter:creator":"@inogic","twitter:image":"http:\/\/1.bp.blogspot.com\/-4phDc0Tyogs\/UTb1FTaeu9I\/AAAAAAAABn4\/W5r2h90tlII\/s1600\/new.png","twitter:label1":"Written by","twitter:data1":"Inogic","twitter:label2":"Est. reading time","twitter:data2":"2 minutes"},"aioseo_meta_data":{"post_id":"36","title":null,"description":null,"keywords":null,"keyphrases":null,"primary_term":null,"canonical_url":null,"og_title":null,"og_description":null,"og_object_type":"default","og_image_type":"default","og_image_url":null,"og_image_width":null,"og_image_height":null,"og_image_custom_url":null,"og_image_custom_fields":null,"og_video":null,"og_custom_url":null,"og_article_section":null,"og_article_tags":null,"twitter_use_og":false,"twitter_card":"default","twitter_image_type":"default","twitter_image_url":null,"twitter_image_custom_url":null,"twitter_image_custom_fields":null,"twitter_title":null,"twitter_description":null,"schema":{"blockGraphs":[],"customGraphs":[],"default":{"data":{"Article":[],"Course":[],"Dataset":[],"FAQPage":[],"Movie":[],"Person":[],"Product":[],"ProductReview":[],"Car":[],"Recipe":[],"Service":[],"SoftwareApplication":[],"WebPage":[]},"graphName":"","isEnabled":true},"graphs":[]},"schema_type":"default","schema_type_options":null,"pillar_content":false,"robots_default":true,"robots_noindex":false,"robots_noarchive":false,"robots_nosnippet":false,"robots_nofollow":false,"robots_noimageindex":false,"robots_noodp":false,"robots_notranslate":false,"robots_max_snippet":null,"robots_max_videopreview":null,"robots_max_imagepreview":"large","priority":null,"frequency":null,"local_seo":null,"breadcrumb_settings":null,"limit_modified_date":false,"ai":null,"created":"2023-02-02 06:02:55","updated":"2025-07-03 22:18:56","seo_analyzer_scan_date":null},"aioseo_breadcrumb":"<div class=\"aioseo-breadcrumbs\"><span class=\"aioseo-breadcrumb\">\n\t\t\t<a href=\"https:\/\/www.inogic.com\/blog\" title=\"Home\">Home<\/a>\n\t\t<\/span><span class=\"aioseo-breadcrumb-separator\">&raquo;<\/span><span class=\"aioseo-breadcrumb\">\n\t\t\t<a href=\"https:\/\/www.inogic.com\/blog\/category\/dynamics-crm\/\" title=\"Dynamics CRM\">Dynamics CRM<\/a>\n\t\t<\/span><span class=\"aioseo-breadcrumb-separator\">&raquo;<\/span><span class=\"aioseo-breadcrumb\">\n\t\t\tAggregate and Grouping functions using LINQ in CRM\n\t\t<\/span><\/div>","aioseo_breadcrumb_json":[{"label":"Home","link":"https:\/\/www.inogic.com\/blog"},{"label":"Dynamics CRM","link":"https:\/\/www.inogic.com\/blog\/category\/dynamics-crm\/"},{"label":"Aggregate and Grouping functions using LINQ in CRM","link":"https:\/\/www.inogic.com\/blog\/2013\/03\/aggregate-and-grouping-functions-using-linq-in-crm\/"}],"_links":{"self":[{"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/posts\/36","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/users\/13"}],"replies":[{"embeddable":true,"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/comments?post=36"}],"version-history":[{"count":0,"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/posts\/36\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/media?parent=36"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/categories?post=36"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.inogic.com\/blog\/wp-json\/wp\/v2\/tags?post=36"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}