当前位置: 首页>>代码示例>>C#>>正文


C# QueryExpression.AddOrder方法代码示例

本文整理汇总了C#中QueryExpression.AddOrder方法的典型用法代码示例。如果您正苦于以下问题:C# QueryExpression.AddOrder方法的具体用法?C# QueryExpression.AddOrder怎么用?C# QueryExpression.AddOrder使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在QueryExpression的用法示例。


在下文中一共展示了QueryExpression.AddOrder方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: When_ordering_by_money_fields_descending_expected_result_is_returned

        public void When_ordering_by_money_fields_descending_expected_result_is_returned()
        {
            List<Entity> contactList = new List<Entity>();

            Entity contact1 = new Entity("contact");
            contact1.Id = Guid.NewGuid();
            contact1.Attributes["firstname"] = "Fred";
            contact1.Attributes["lastname"] = "Bloggs";
            contact1.Attributes["new_somefield"] = new Money(12345); // (decimal)678910 

            Entity contact2 = new Entity("contact");
            contact2.Id = Guid.NewGuid();
            contact2.Attributes["firstname"] = "Jo";
            contact2.Attributes["lastname"] = "Bloggs";
            contact2.Attributes["new_somefield"] = new Money(678910); // (decimal)678910 


            contactList.Add(contact2);
            contactList.Add(contact1);

            var context = new XrmFakedContext();
            context.Initialize(contactList);
            var service = context.GetFakedOrganizationService();

            QueryExpression qry = new QueryExpression("contact");
            qry.ColumnSet = new ColumnSet(true);
            qry.AddOrder("new_somefield", OrderType.Descending);
            var results = service.RetrieveMultiple(qry);

            var firstResultValue = results.Entities[0]["new_somefield"] as Money;

            Assert.Equal(678910M, firstResultValue.Value);
        }
开发者ID:ccellar,项目名称:fake-xrm-easy,代码行数:33,代码来源:OrderByTests.cs

示例2: When_ordering_by_datetime_fields_expected_result_is_returned

        public void When_ordering_by_datetime_fields_expected_result_is_returned()
        {
            List<Entity> contactList = new List<Entity>();

            var now = DateTime.UtcNow;
            Entity contact1 = new Entity("contact");
            contact1.Id = Guid.NewGuid();
            contact1.Attributes["firstname"] = "Fred";
            contact1.Attributes["new_orderbyfield"] = now;

            Entity contact2 = new Entity("contact");
            contact2.Id = Guid.NewGuid();
            contact2.Attributes["firstname"] = "Jo";
            contact2.Attributes["new_orderbyfield"] = now.AddDays(1);

            contactList.Add(contact2);
            contactList.Add(contact1);

            var context = new XrmFakedContext();
            context.Initialize(contactList);
            var service = context.GetFakedOrganizationService();

            QueryExpression qry = new QueryExpression("contact");
            qry.ColumnSet = new ColumnSet(true);
            qry.AddOrder("new_orderbyfield", OrderType.Ascending);
            var results = service.RetrieveMultiple(qry);

            var firstResultValue = (DateTime)results.Entities[0]["new_orderbyfield"];

            Assert.Equal(now, firstResultValue);
        }
开发者ID:DigitalFlow,项目名称:fake-xrm-easy,代码行数:31,代码来源:OrderByTests.cs

示例3: GetUsers

        /// <summary>
        /// Obtains all users corresponding to the search filter
        /// </summary>
        /// <param name="value">Search filter</param>
        /// <returns>List of users matching the search filter</returns>
        public List<Entity> GetUsers(string value)
        {
            var users = new List<Entity>();

            var ceStatus = new ConditionExpression("isdisabled", ConditionOperator.Equal, false);

            var feStatus = new FilterExpression();
            feStatus.AddCondition(ceStatus);

            var qe = new QueryExpression("systemuser");
            qe.ColumnSet = new ColumnSet("systemuserid", "fullname", "lastname", "firstname", "domainname", "businessunitid");
            qe.AddOrder("lastname", OrderType.Ascending);
            qe.Criteria = new FilterExpression();
            qe.Criteria.Filters.Add(new FilterExpression());
            qe.Criteria.Filters[0].FilterOperator = LogicalOperator.And;
            qe.Criteria.Filters[0].Filters.Add(feStatus);
            qe.Criteria.Filters[0].Filters.Add(new FilterExpression());
            qe.Criteria.Filters[0].Filters[1].FilterOperator = LogicalOperator.Or;

            if (value.Length > 0)
            {
                bool isGuid = false;

                try
                {
                    Guid g = new Guid(value);
                    isGuid = true;
                }
                catch
                { }

                if (isGuid)
                {
                    var ce = new ConditionExpression("systemuserid", ConditionOperator.Equal, value);
                    qe.Criteria.Filters[0].Filters[1].AddCondition(ce);
                }
                else
                {
                    var ce = new ConditionExpression("fullname", ConditionOperator.Like, value.Replace("*", "%"));
                    var ce2 = new ConditionExpression("firstname", ConditionOperator.Like, value.Replace("*", "%"));
                    var ce3 = new ConditionExpression("lastname", ConditionOperator.Like, value.Replace("*", "%"));
                    var ce4 = new ConditionExpression("domainname", ConditionOperator.Like, value.Replace("*", "%"));

                    qe.Criteria.Filters[0].Filters[1].AddCondition(ce);
                    qe.Criteria.Filters[0].Filters[1].AddCondition(ce2);
                    qe.Criteria.Filters[0].Filters[1].AddCondition(ce3);
                    qe.Criteria.Filters[0].Filters[1].AddCondition(ce4);
                }
            }

            foreach (var record in service.RetrieveMultiple(qe).Entities)
            {
                users.Add(record);
            }

            return users;
        }
开发者ID:NORENBUCH,项目名称:XrmToolBox,代码行数:62,代码来源:CrmAccess.cs

示例4: LoadViews

        internal void LoadViews(Action action)
        {
            this.host.WorkAsync("Loading views...",
                (a) =>
                {
                    this.views = new Dictionary<string, List<Entity>>();

                    if (views.Count == 0)
                    {
                        var combinedResult = new Dictionary<string, DataCollection<Entity>>();
                        DataCollection<Entity> singleResult;

                        var qex = new QueryExpression();

                        qex.ColumnSet = new ColumnSet("name", "returnedtypecode", "fetchxml", "layoutxml");
                        qex.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
                        qex.Criteria.AddCondition("querytype", ConditionOperator.In, 0, 32);
                        qex.AddOrder("name", OrderType.Ascending);

                        foreach (var entity in new string[] { "savedquery", "userquery" })
                        {
                            qex.EntityName = entity;

                            singleResult = this.host.Service.RetrieveMultiple(qex).Entities;
                            if (singleResult.Count > 0)
                            {
                                combinedResult.Add(qex.EntityName, singleResult);
                            }
                        }

                        a.Result = combinedResult;
                    }
                },
                (a) =>
                {
                    var allViews = (Dictionary<string, DataCollection<Entity>>)a.Result;

                    foreach (var key in allViews.Keys)
                    {
                        this.ExtractViews(allViews[key]);
                    }

                    this.entities = this.views.Keys.Select(x => x.Split('|')[0]).Distinct().ToList();

                    action();
                });
        }
开发者ID:rajyraman,项目名称:XrmToolBox.Plugins,代码行数:47,代码来源:SelectViewDialog.cs

示例5: LoadViews

 internal void LoadViews(Action viewsLoaded)
 {
     if (working)
     {
         return;
     }
     if (entities == null || entities.Count == 0)
     {
         LoadEntities(viewsLoaded);
         return;
     }
     working = true;
     WorkAsync("Loading views...",
         (bgworker, workargs) =>
         {
             EnableControls(false);
             if (views == null || views.Count == 0)
             {
                 if (Service == null)
                 {
                     throw new Exception("Need a connection to load views.");
                 }
                 var qex = new QueryExpression("savedquery");
                 qex.ColumnSet = new ColumnSet("name", "returnedtypecode", "fetchxml");
                 qex.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
                 qex.Criteria.AddCondition("querytype", ConditionOperator.In, 0, 32);
                 qex.AddOrder("name", OrderType.Ascending);
                 bgworker.ReportProgress(33, "Loading system views...");
                 var sysviews = Service.RetrieveMultiple(qex);
                 foreach (var view in sysviews.Entities)
                 {
                     var entityname = view["returnedtypecode"].ToString();
                     if (!string.IsNullOrWhiteSpace(entityname) && entities.ContainsKey(entityname))
                     {
                         if (views == null)
                         {
                             views = new Dictionary<string, List<Entity>>();
                         }
                         if (!views.ContainsKey(entityname + "|S"))
                         {
                             views.Add(entityname + "|S", new List<Entity>());
                         }
                         views[entityname + "|S"].Add(view);
                     }
                 }
                 qex.EntityName = "userquery";
                 bgworker.ReportProgress(66, "Loading user views...");
                 var userviews = Service.RetrieveMultiple(qex);
                 foreach (var view in userviews.Entities)
                 {
                     var entityname = view["returnedtypecode"].ToString();
                     if (!string.IsNullOrWhiteSpace(entityname) && entities.ContainsKey(entityname))
                     {
                         if (views == null)
                         {
                             views = new Dictionary<string, List<Entity>>();
                         }
                         if (!views.ContainsKey(entityname + "|U"))
                         {
                             views.Add(entityname + "|U", new List<Entity>());
                         }
                         views[entityname + "|U"].Add(view);
                     }
                 }
                 bgworker.ReportProgress(100, "Finalizing...");
             }
         },
         (completedargs) =>
         {
             working = false;
             EnableControls(true);
             if (completedargs.Error != null)
             {
                 MessageBox.Show(completedargs.Error.Message);
             }
             else
             {
                 viewsLoaded();
             }
         },
         (changeargs) =>
         {
             SetWorkingMessage(changeargs.UserState.ToString());
         });
 }
开发者ID:rajyraman,项目名称:XrmToolBox.Plugins,代码行数:85,代码来源:MainControl.cs

示例6: BuildQueryActive

        public static QueryExpression BuildQueryActive(string entityType, IEnumerable<string> fields,
            IEnumerable<ConditionExpression> filters, string[] sortFields)
        {
            var query = new QueryExpression(entityType);
            query.Criteria.AddCondition("statecode", ConditionOperator.Equal, XrmPicklists.State.Active);
            if (filters != null)
            {
                foreach (var condition in filters)
                    query.Criteria.AddCondition(condition);
            }
            if (sortFields != null)
            {
                foreach (var sortField in sortFields)
                    query.AddOrder(sortField, OrderType.Ascending);
            }
            if (fields != null)
                query.ColumnSet = new ColumnSet(fields.ToArray());
            else
                query.ColumnSet = new ColumnSet(true);

            return query;
        }
开发者ID:josephmcmac,项目名称:JosephM.Xrm,代码行数:22,代码来源:XrmService.cs

示例7: BuildQuery

        public static QueryExpression BuildQuery(string entityType, IEnumerable<string> fields,
            IEnumerable<ConditionExpression> filters, IEnumerable<string> sortFields)
        {
            var query = new QueryExpression(entityType);
            if (filters != null)
            {
                foreach (var condition in filters)
                    query.Criteria.AddCondition(condition);
            }
            if (sortFields != null)
            {
                foreach (var sortField in sortFields)
                    query.AddOrder(sortField, OrderType.Ascending);
            }
            if (fields != null)
                query.ColumnSet = new ColumnSet(fields.ToArray());
            else
                query.ColumnSet = new ColumnSet(true);

            return query;
        }
开发者ID:josephmcmac,项目名称:JosephM.Xrm,代码行数:21,代码来源:XrmService.cs

示例8: AddOrderExpressions

 private static void AddOrderExpressions(QueryExpression query, IEnumerable<OrderExpression> orders)
 {
     if (orders != null)
     {
         foreach (var order in orders)
             query.AddOrder(order.AttributeName, order.OrderType);
     }
 }
开发者ID:josephmcmac,项目名称:JosephM.Xrm,代码行数:8,代码来源:XrmService.cs

示例9: lastActivity

    protected DateTime lastActivity(string username, string subject)
    {
        using (OrganizationService service = new OrganizationService(OurConnect()))
        {
            ConditionExpression toCondition = new ConditionExpression();
            ConditionExpression fromCondition = new ConditionExpression();
            ConditionExpression subjectCondition = new ConditionExpression();

            toCondition.AttributeName = consts.to;
            toCondition.Operator = ConditionOperator.Equal;
            toCondition.Values.Add(username);

            fromCondition.AttributeName = consts.from;
            fromCondition.Operator = ConditionOperator.Equal;
            fromCondition.Values.Add(_ApplicationName);

            FilterExpression filter = new FilterExpression();
            filter.Conditions.Add(toCondition);
            filter.Conditions.Add(fromCondition);

            if (subject != String.Empty)
            {
                subjectCondition.AttributeName = consts.subject;
                subjectCondition.Operator = ConditionOperator.Equal;
                subjectCondition.Values.Add(subject);
            }

            QueryExpression query = new QueryExpression(consts.activities);

            query.ColumnSet.AddColumn(consts.activitytime);
            query.AddOrder(consts.activitytime, OrderType.Descending);
            query.Criteria.AddFilter(filter);

            EntityCollection collection = service.RetrieveMultiple(query);
            return (DateTime)collection.Entities[0][consts.activitytime];
        }
    }
开发者ID:RosettaMktg,项目名称:CrmProvider,代码行数:37,代码来源:CustomProfileProvider.cs

示例10: getWorkflows

        private void getWorkflows()
        {
            #region Reset Variables

            ExecutionRecordSet.Entities.Clear();
            _workflows.Entities.Clear();
            _selectedWorkflow = null;
            _views.Entities.Clear();
            _selectedView = null;

            this.Invoke((MethodInvoker)delegate()
            {
                cmbWorkflows.Items.Clear();
                cmbViews.Items.Clear();
                txtRecordCount.Clear();
                rtxtFetchXML.Clear();
                radFetchXML.Checked = false;
                radViews.Checked = true;
                //progressBar1.Style = ProgressBarStyle.Marquee;
                txtBatch.Text = "200";
                emrBatchSize = 200;
            });

            #endregion Reset Variables

            #region Get Workflows Query

            QueryExpression query = new QueryExpression("workflow");
            query.ColumnSet.AddColumns("workflowid", "name", "primaryentity");
            query.Distinct = true;
            query.AddOrder("name", OrderType.Ascending);
            query.Criteria = new FilterExpression();
            //query.Criteria.AddCondition("category", ConditionOperator.Equal, 0);

            FilterExpression childFilter = query.Criteria.AddFilter(LogicalOperator.And);
            childFilter.AddCondition("category", ConditionOperator.Equal, 0);
            childFilter.AddCondition("activeworkflowid", ConditionOperator.NotNull);
            childFilter.AddCondition("ondemand", ConditionOperator.Equal, true);

            _workflows = service.RetrieveMultiple(query);
            if (_workflows.Entities.Count > 0)
            {
                foreach (var item in _workflows.Entities)
                {
                    this.Invoke((MethodInvoker)delegate()
                    {
                        cmbWorkflows.Items.Add(item["name"]);
                    });
                }
            }
            this.Invoke((MethodInvoker)delegate()
            {
                cmbWorkflows.Text = "Select a Workflow to run";
                cmbViews.Text = "Select a Workflow to populate this list";
                //progressBar1.Style = ProgressBarStyle.Continuous;
            });

            infoPanel.Dispose();
            infoPanel.Dispose();
            Controls.Remove(infoPanel);

            #endregion Get Workflows Query
        }
开发者ID:drojkovic,项目名称:XrmToolBox-CRMBulkWorkflowTool,代码行数:63,代码来源:MainControl.cs

示例11: LoadAssemblies

        private Task<List<Assembly>> LoadAssemblies()
        {
            return Task.Run(() =>
            {
                var query = new QueryExpression("pluginassembly");
                query.Distinct = true;
                query.NoLock = true;
                query.ColumnSet = new ColumnSet("name", "pluginassemblyid");
                query.AddOrder("name", OrderType.Ascending);
                var type = query.AddLink("plugintype", "pluginassemblyid", "pluginassemblyid", JoinOperator.Inner);
                type.LinkCriteria.AddCondition("typename", ConditionOperator.NotLike, "Microsoft.Crm.%");
                type.LinkCriteria.AddCondition("typename", ConditionOperator.NotLike, "ActivityFeeds.%");

                var result = _service.RetrieveMultiple(query);

                var assemblies = result.Entities.Select(e => new Assembly
                {
                    AssemblyId = e.Id,
                    Export = false,
                    Name = e["name"] as string,
                    RegisteredStepCount = 0
                }).ToList();

                foreach (var assembly in assemblies)
                {
                    query = new QueryExpression("sdkmessageprocessingstep");
                    query.Distinct = true;
                    query.NoLock = true;
                    query.ColumnSet = new ColumnSet("sdkmessageprocessingstepid");
                    type = query.AddLink("plugintype", "plugintypeid", "plugintypeid");
                    type.LinkCriteria.AddCondition("pluginassemblyid", ConditionOperator.Equal, assembly.AssemblyId);

                    result = _service.RetrieveMultiple(query);

                    assembly.RegisteredStepCount = result.Entities.Count;
                }

                return assemblies;
            });
        }
开发者ID:gotdibbs,项目名称:magician,代码行数:40,代码来源:ControlViewModel.cs

示例12: Get

        public static IEnumerable<Entity> Get(
           this IOrganizationService service,
            out int totalItemsCount,
           string entityname,
           bool allattributes = false,
           IEnumerable<OrderBy> orders = null,
           IEnumerable<ConditionExpression> conditions = null,
           IEnumerable<string> attrs = null,
           int? page = null,
           int? count = null)
        {
            ObjectCacheManager.GetInstance().Clear();

            if (string.IsNullOrEmpty(entityname)) throw new ArgumentNullException("entityname");

            var query = new QueryExpression(entityname);

            if (attrs != null)
            {
                var a = attrs.ToArray();

                if (allattributes)
                {
                    query.ColumnSet = new ColumnSet(true);
                }
                else
                {
                    query.ColumnSet = a.Count() == 0 ? new ColumnSet(false) : new ColumnSet(a);
                }
            }

            if (conditions != null)
            {
                conditions.ToList().ForEach(x => { query.Criteria.AddCondition(x); });
            }

            if (orders != null)
            {
                orders.ToList().ForEach(x => { query.AddOrder(x.AttributeName, x.OrderType); });
            }

            List<Entity> ents;

            totalItemsCount = 0;

            if (page != null && count != null)
            {
                query.PageInfo = new PagingInfo
                {
                    Count = count.Value,
                    PageNumber = page.Value,
                    PagingCookie = null,
                    ReturnTotalRecordCount = true
                };

                ents = service.GetPage(query, out totalItemsCount);
            }
            else
            {
                ents = service.GetAllEntities(query);
            }

            return ents;
        }
开发者ID:ap1ter,项目名称:CrmExts,代码行数:64,代码来源:OrganizationServiceExtensions.cs

示例13: When_ordering_by_guid_fields_expected_result_is_returned

        public void When_ordering_by_guid_fields_expected_result_is_returned()
        {
            List<Entity> contactList = new List<Entity>();

            var g1 = new Guid(12, 0, 0, new byte[] {  new byte(), new byte(), new byte(), new byte(),
                                                      new byte(), new byte(), new byte(), new byte()  });
            var g2 = new Guid(24, 0, 0, new byte[] {  new byte(), new byte(), new byte(), new byte(),
                                                      new byte(), new byte(), new byte(), new byte()  });

            Entity contact1 = new Entity("contact");
            contact1.Id = Guid.NewGuid();
            contact1.Attributes["firstname"] = "Fred";
            contact1.Attributes["new_orderbyfield"] = g1;

            Entity contact2 = new Entity("contact");
            contact2.Id = Guid.NewGuid();
            contact2.Attributes["firstname"] = "Jo";
            contact2.Attributes["new_orderbyfield"] = g2;

            contactList.Add(contact2);
            contactList.Add(contact1);

            var context = new XrmFakedContext();
            context.Initialize(contactList);
            var service = context.GetFakedOrganizationService();

            QueryExpression qry = new QueryExpression("contact");
            qry.ColumnSet = new ColumnSet(true);
            qry.AddOrder("new_orderbyfield", OrderType.Ascending);
            var results = service.RetrieveMultiple(qry);

            var firstResultValue = (Guid)results.Entities[0]["new_orderbyfield"];

            Assert.Equal(g1, firstResultValue);
        }
开发者ID:DigitalFlow,项目名称:fake-xrm-easy,代码行数:35,代码来源:OrderByTests.cs

示例14: LocalCrmTests_OrderBy

        public void LocalCrmTests_OrderBy()
        {
            var service = GetService();
            service.Create(new Contact() {FirstName = "Chuck", LastName = "Adams"});
            service.Create(new Contact() {FirstName = "Anna", LastName = "Adams"});
            service.Create(new Contact() {FirstName = "Bill", LastName = "Adams"});

            var qe = new QueryExpression(Contact.EntityLogicalName);
            qe.ColumnSet = new ColumnSet(true);

            // Ascending Order Test
            qe.AddOrder("firstname", OrderType.Ascending);
            var results = service.GetEntities<Contact>(qe);

            Assert.AreEqual("Anna", results[0].FirstName, "Ascending Ordering failed.  \"Anna\" should have been returned first");
            Assert.AreEqual("Bill", results[1].FirstName, "Ascending Ordering failed.  \"Bill\" should have been returned second");
            Assert.AreEqual("Chuck", results[2].FirstName, "Ascending Ordering failed.  \"Chuck\" should have been returned third");

            // Descending Order Test
            qe.Orders[0].OrderType = OrderType.Descending;
            results = service.GetEntities<Contact>(qe);

            Assert.AreEqual("Chuck", results[0].FirstName, "Descending Ordering failed.  \"Chuck\" should have been returned first");
            Assert.AreEqual("Bill", results[1].FirstName, "Descending Ordering failed.  \"Bill\" should have been returned second");
            Assert.AreEqual("Anna", results[2].FirstName, "Descending Ordering failed.  \"Anna\" should have been returned third");

            // Add Dups
            service.Create(new Contact() {FirstName = "Chuck", LastName = "Bell"});
            service.Create(new Contact() {FirstName = "Anna", LastName = "Bell"});
            service.Create(new Contact() {FirstName = "Anna", LastName = "Carter"});
            service.Create(new Contact() {FirstName = "Bill", LastName = "Bell"});
            service.Create(new Contact() {FirstName = "Bill", LastName = "Carter"});
            service.Create(new Contact() {FirstName = "Chuck", LastName = "Carter"});

            // Order By Descending First Then By Ascending Last Test
            qe.AddOrder("lastname", OrderType.Ascending);
            results = service.GetEntities<Contact>(qe);

            Assert.AreEqual("Chuck Adams", results[0].FullName, "Descending then Ascending Ordering failed.  \"Chuck Adams\" should have been returned first");
            Assert.AreEqual("Chuck Bell", results[1].FullName, "Descending then Ascending Ordering failed.  \"Chuck Bell\" should have been returned second");
            Assert.AreEqual("Chuck Carter", results[2].FullName, "Descending then Ascending Ordering failed.  \"Chuck Carter\" should have been returned third");
            Assert.AreEqual("Bill Adams", results[3].FullName, "Descending then Ascending Ordering failed.  \"Bill Adams\" should have been returned forth");
            Assert.AreEqual("Bill Bell", results[4].FullName, "Descending then Ascending Ordering failed.  \"Bill Bell\" should have been returned fifth");
            Assert.AreEqual("Bill Carter", results[5].FullName, "Descending then Ascending Ordering failed.  \"Bill Carter\" should have been returned sixth");
            Assert.AreEqual("Anna Adams", results[6].FullName, "Descending then Ascending Ordering failed.  \"Anna Adams\" should have been returned seventh");
            Assert.AreEqual("Anna Bell", results[7].FullName, "Descending then Ascending Ordering failed.  \"Anna Bell\" should have been returned eighth");
            Assert.AreEqual("Anna Carter", results[8].FullName, "Descending then Ascending Ordering failed.  \"Anna Carter\" should have been returned nineth");

            // Order By Ascending First Then By Descending Last Test
            qe.Orders.Clear();
            qe.AddOrder("firstname", OrderType.Ascending);
            qe.AddOrder("lastname", OrderType.Descending);
            results = service.GetEntities<Contact>(qe);

            Assert.AreEqual("Anna Carter", results[0].FullName, "Ascending then Descending Ordering failed.  \"Anna Carter\" should have been returned first");
            Assert.AreEqual("Anna Bell", results[1].FullName, "Ascending then Descending Ordering failed.  \"Anna Bell\" should have been returned second");
            Assert.AreEqual("Anna Adams", results[2].FullName, "Ascending then Descending Ordering failed.  \"Anna Adams\" should have been returned thrid");
            Assert.AreEqual("Bill Carter", results[3].FullName, "Ascending then Descending Ordering failed.  \"Bill Carter\" should have been returned forth");
            Assert.AreEqual("Bill Bell", results[4].FullName, "Ascending then Descending Ordering failed.  \"Bill Bell\" should have been returned fifth");
            Assert.AreEqual("Bill Adams", results[5].FullName, "Ascending then Descending Ordering failed.  \"Bill Adams\" should have been returned sixth");
            Assert.AreEqual("Chuck Carter", results[6].FullName, "Ascending then Descending Ordering failed.  \"Chuck Carter\" should have been returned seventh");
            Assert.AreEqual("Chuck Bell", results[7].FullName, "Ascending then Descending Ordering failed.  \"Chuck Bell\" should have been returned eighth");
            Assert.AreEqual("Chuck Adams", results[8].FullName, "Ascending then Descending Ordering failed.  \"Chuck Adams\" should have been returned nineth");

            // Order by Date Ascending
            qe.Orders.Clear();
            qe.AddOrder("createdon", OrderType.Ascending);
            results = service.GetEntities<Contact>(qe);

            Assert.AreEqual("Adams", results[0].LastName, "Ascending Date Ordering failed.  \"Adams\" should have been returned first");
            Assert.AreEqual("Adams", results[1].LastName, "Ascending Date Ordering failed.  \"Adams\" should have been returned first");
            Assert.AreEqual("Adams", results[2].LastName, "Ascending Date Ordering failed.  \"Adams\" should have been returned first");

            // Order by Date Descending
            qe.Orders.Clear();
            qe.AddOrder("createdon", OrderType.Descending);
            results = service.GetEntities<Contact>(qe);

            Assert.AreEqual("Adams", results[8].LastName, "Ascending Date Ordering failed.  \"Adams\" should have been returned last");
            Assert.AreEqual("Adams", results[7].LastName, "Ascending Date Ordering failed.  \"Adams\" should have been returned last");
            Assert.AreEqual("Adams", results[6].LastName, "Ascending Date Ordering failed.  \"Adams\" should have been returned last");
        }
开发者ID:gitter-badger,项目名称:XrmUnitTest,代码行数:82,代码来源:LocalCrmTests.cs

示例15: LoadRoles

        private Task<List<Role>> LoadRoles()
        {
            return Task.Run(() =>
            {
                var query = new QueryExpression("role");
                query.NoLock = true;
                query.ColumnSet = new ColumnSet("name", "roleid");
                query.AddOrder("name", OrderType.Ascending);
                var bu = query.AddLink("businessunit", "businessunitid", "businessunitid");
                bu.LinkCriteria.AddCondition("parentbusinessunitid", ConditionOperator.Null);

                var result = _service.RetrieveMultiple(query);

                var roles = result.Entities.Select(e => new Role
                {
                    RoleId = e.Id,
                    Name = e["name"] as string
                });

                roles = roles.Concat(new Role[] {
                    new Role
                    {
                        RoleId = Guid.Empty,
                        Name = " -- Users without an assigned role -- "
                    }
                });

                return roles.OrderBy(r => r.Name).ToList();
            });
        }
开发者ID:gotdibbs,项目名称:magician,代码行数:30,代码来源:ControlViewModel.cs


注:本文中的QueryExpression.AddOrder方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。