zoukankan      html  css  js  c++  java
  • crm使用FetchXml分组聚合查询

    /* 创建者:菜刀居士的博客
     * 创建日期:2014年07月09号
     */

    namespace Net.CRM.FetchXml
    {
        using System;
        using Microsoft.Xrm.Sdk;
        using Microsoft.Xrm.Sdk.Query;

        /// <summary>
        /// 使用FetchXml聚合查询,分组根据
        /// </summary>
        public class FetchXmlExtension
        {
            /// <summary>
            /// 分组聚合
            /// sql: select count(*),ownerid from account group by ownerid
            /// </summary>
            public void Group(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                            <attribute name='name' alias='name_count' aggregate='count' />
                                            <attribute name='ownerid' alias='ownerid' groupby='true' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    decimal value = ((Money)((AliasedValue)en["name_count"]).Value).Value;
                    EntityReference ownerEr = (EntityReference)((AliasedValue)en["ownerid"]).Value;
                }
            }

            /// <summary>
            /// 分组聚合,按年分组
            /// </summary>
            public void GroupByYear(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                           <attribute name='accountid' alias='account_count' aggregate='count'/>
                                           <attribute name='estimatedvalue' alias='estimatedvalue_sum' aggregate='sum'/> 
                                           <attribute name='actualclosedate' groupby='true' dategrouping='year' alias='year' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    int value_year = (Int32)((AliasedValue)en["year"]).Value;
                    int value_count = (Int32)((AliasedValue)en["account_count"]).Value;
                    decimal value_sum = ((Money)((AliasedValue)en["estimatedvalue_sum"]).Value).Value;
                }
            }

            /// <summary>
            /// 分组聚合,按季度分组
            /// </summary>
            public void GroupByQuarter(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                           <attribute name='accountid' alias='account_count' aggregate='count'/>
                                           <attribute name='estimatedvalue' alias='estimatedvalue_sum' aggregate='sum'/> 
                                           <attribute name='actualclosedate' groupby='true' dategrouping='quarter' alias='quarter' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    int value_quarter = (Int32)((AliasedValue)en["quarter"]).Value;
                    int value_count = (Int32)((AliasedValue)en["account_count"]).Value;
                    decimal value_sum = ((Money)((AliasedValue)en["estimatedvalue_sum"]).Value).Value;
                }
            }

            /// <summary>
            /// 分组聚合,按月分组
            /// </summary>
            public void GroupByMonth(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                           <attribute name='accountid' alias='account_count' aggregate='count'/>
                                           <attribute name='estimatedvalue' alias='estimatedvalue_sum' aggregate='sum'/> 
                                           <attribute name='actualclosedate' groupby='true' dategrouping='month' alias='month' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    int value_month = (Int32)((AliasedValue)en["month"]).Value;
                    int value_count = (Int32)((AliasedValue)en["account_count"]).Value;
                    decimal value_sum = ((Money)((AliasedValue)en["estimatedvalue_sum"]).Value).Value;
                }
            }

            /// <summary>
            /// 分组聚合,按周分组
            /// </summary>
            public void GroupByWeek(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                           <attribute name='accountid' alias='account_count' aggregate='count'/>
                                           <attribute name='estimatedvalue' alias='estimatedvalue_sum' aggregate='sum'/> 
                                           <attribute name='actualclosedate' groupby='true' dategrouping='week' alias='week' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    int value_week = (Int32)((AliasedValue)en["week"]).Value;
                    int value_count = (Int32)((AliasedValue)en["account_count"]).Value;
                    decimal value_sum = ((Money)((AliasedValue)en["estimatedvalue_sum"]).Value).Value;
                }
            }

            /// <summary>
            /// 分组聚合,按日分组
            /// </summary>
            public void GroupByDay(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                           <attribute name='accountid' alias='account_count' aggregate='count'/>
                                           <attribute name='estimatedvalue' alias='estimatedvalue_sum' aggregate='sum'/> 
                                           <attribute name='actualclosedate' groupby='true' dategrouping='day' alias='day' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    int value_day = (Int32)((AliasedValue)en["day"]).Value;
                    int value_count = (Int32)((AliasedValue)en["account_count"]).Value;
                    decimal value_sum = ((Money)((AliasedValue)en["estimatedvalue_sum"]).Value).Value;
                }
            }

            /// <summary>
            /// 分组聚合,多个分组根据
            /// </summary>
            public void GroupByYearAndQuarter(IOrganizationService service)
            {
                string fetchXml = @"<fetch distinct='false' mapping='logical' aggregate='true'>
                                        <entity name='account'>
                                           <attribute name='accountid' alias='account_count' aggregate='count'/>
                                           <attribute name='estimatedvalue' alias='estimatedvalue_sum' aggregate='sum'/> 
                                           <attribute name='actualclosedate' groupby='true' dategrouping='year' alias='year' />
                                           <attribute name='actualclosedate' groupby='true' dategrouping='quarter' alias='quarter' />
                                        </entity>
                                    </fetch>";
                EntityCollection ec = service.RetrieveMultiple(new FetchExpression(fetchXml));
                if (ec != null && ec.Entities.Count > 0)
                {
                    Entity en = ec.Entities[0];
                    //获取结果
                    int value_year = (Int32)((AliasedValue)en["year"]).Value;
                    int value_quarter = (Int32)((AliasedValue)en["quarter"]).Value;
                    int value_count = (Int32)((AliasedValue)en["account_count"]).Value;
                    decimal value_sum = ((Money)((AliasedValue)en["estimatedvalue_sum"]).Value).Value;
                }
            }
        }
    }

  • 相关阅读:
    (webservice,ajax,jmail)Tip:动态调用webservice,ajaxpro的使用要点以及使用jmail接口使用注意事项
    (virus)Error Cleaner, Privacy Protector, Spyware&Malware Protection的罪恶
    (tips,javascript,office)客户端操作excel文档的注意事项
    (iis,asp.net)Tip:错误"由于 ASP.NET 进程标识对全局程序集缓存没有读权限,因此未能执行请求。错误: 0x80070005 拒绝访问"的解决办法
    (javascript)常用农历(12生肖年,天干地支,节气)
    (Life)质量和服务_由购买联想笔记本想到的
    (enjoyment,basketball)随便说说我们的NBA
    (javascript)再说document.body.scrollTop的使用问题
    IE7下使用htmleditor的问题
    POJ 1077 Eight(BFS + A* + 逆序对剪枝)
  • 原文地址:https://www.cnblogs.com/slgkaifa/p/6940474.html
Copyright © 2011-2022 走看看