博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
crm高速开发之QueryExpression
阅读量:6669 次
发布时间:2019-06-25

本文共 3161 字,大约阅读时间需要 10 分钟。

/* 创建者:菜刀居士的博客

 * 创建日期:2014年07月06号
 */

namespace Net.CRM.OrganizationService

{
    using System;
    using Microsoft.Xrm.Sdk;
    using Microsoft.Xrm.Sdk.Query;
    using System.Collections.Generic;

    /// <summary>

    /// QueryExpression
    /// </summary>
    public class QueryExpressionDemo
    {
        /// <summary>
        /// 基本模式,构造查询--QueryExpression
        /// </summary>
        public void CreateQueryExpression()
        {
            QueryExpression query = new QueryExpression();
            //查询的实体名称
            query.EntityName = "new_accountproduct";
            //查询实体的属性集合
            query.ColumnSet = new ColumnSet("new_product","new_name","new_price");
            //查询条件
            query.Criteria.AddCondition(new ConditionExpression("statecode",ConditionOperator.Equal,0));
            query.Criteria.AddCondition(new ConditionExpression("new_name", ConditionOperator.Like, "水果" + "%"));
            List<Guid> list = new List<Guid>();
            list.Add(new Guid("27BB1B31-09BB-E311-B590-D89D671782D3"));
            list.Add(new Guid("E8F8D412-31BB-E311-B590-D89D671782D3"));
            query.Criteria.AddCondition(new ConditionExpression("new_product",ConditionOperator.In,list.ToArray()));
            query.Criteria.AddCondition(new ConditionExpression("new_name", ConditionOperator.NotNull));
            query.Criteria.AddCondition(new ConditionExpression("new_price", ConditionOperator.Null));
        }

        /// <summary>

        /// 高速模式,构造查询--QueryExpression
        /// </summary>
        public void CreateQuickQueryExpression()
        {
            QueryExpression query = "new_accountproduct".ToQuery("new_product", "new_name", "new_price");
            query.AddEqual("statecode", 0);
            query.AddLike("new_name", "水果" + "%");
            List<Guid> list = new List<Guid>();
            list.Add(new Guid("27BB1B31-09BB-E311-B590-D89D671782D3"));
            list.Add(new Guid("E8F8D412-31BB-E311-B590-D89D671782D3"));
            query.AddIn("new_product", list.ToArray());
            query.AddNotNull("new_name");
            query.AddNull("new_price");
        }

    }

    public static class ExtensionFunction

    {
        public static QueryExpression ToQuery(this string entityName)
        {
            QueryExpression query = new QueryExpression();
            query.EntityName = entityName;
            return query;
        }

        public static QueryExpression ToQuery(this string entityName,params string[] Attrs)

        {
            QueryExpression query = new QueryExpression();
            query.EntityName = entityName;
            query.ColumnSet = new ColumnSet(Attrs);
            return query;
        }

        public static void AddEqual<T>(this QueryExpression query,string name,T value)

        {
            query.Criteria.AddCondition(new ConditionExpression(name,ConditionOperator.Equal,value));
        }

        public static void AddLike(this QueryExpression query, string name,string value)

        {
            query.Criteria.AddCondition(new ConditionExpression(name,ConditionOperator.Like,value));
        }

        public static void AddIn<T>(this QueryExpression query, string name,T[] values)

        {
            query.Criteria.AddCondition(new ConditionExpression(name, ConditionOperator.In, values));
        }

        public static void AddNotNull(this QueryExpression query,params string[] attrs)

        {
            if (attrs != null && attrs.Length > 0)
            {
                foreach(string name in attrs)
                {
                    query.Criteria.AddCondition(new ConditionExpression(name, ConditionOperator.NotNull));
                }
            }
        }

        public static void AddNull(this QueryExpression query, params string[] attrs)

        {
            if (attrs != null && attrs.Length > 0)
            {
                foreach (string name in attrs)
                {
                    query.Criteria.AddCondition(new ConditionExpression(name, ConditionOperator.Null));
                }
            }
        }
    }

}

对照:

 

 

 

 

你可能感兴趣的文章
Host '192.168.1.21' is not allowed to connect to this MySQL server
查看>>
【前端攻略】:玩转图片Base64编码
查看>>
Oracle 12c安装报错Installation failed to access the temporary location(无法访问临时位置)...
查看>>
iOS-常见的几种UI布局技巧
查看>>
约瑟夫环之递归算法
查看>>
linux进程的休眠(等待队列)【转】
查看>>
javascript基础知识
查看>>
LeetCode OJ:Integer to Roman(转换整数到罗马字符)
查看>>
redis在Linux上的安装
查看>>
msf
查看>>
灵活就业协议影响应届身份吗,档案应该如何处理
查看>>
校招开篇第一次面试——打响校招的第一枪(二)
查看>>
SQLServer函数 left()、charindex()、stuff()的使用
查看>>
高效能人士
查看>>
C语言博客作业2--循环结构
查看>>
Unity 框架篇
查看>>
iOS自定义发送消息输入框
查看>>
EasyUI笔记(五)表单
查看>>
电动汽车与ADAS
查看>>
微信jsapi支付
查看>>