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

 * 创建日期: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));

                }

            }

        }

    }

}

对照:

crm高速开发之QueryExpression的更多相关文章

  1. crm高速开发之EntityCollection

    /* 创建者:菜刀居士的博客  * 创建日期:2014年07月07号  */ namespace Net.CRM.OrganizationService {     using System;     ...

  2. crm高速开发之OrganizationService

    这是主要的开发模式: /* 创建者:菜刀居士的博客  * 创建日期:2014年07月06号  */ namespace Net.CRM.OrganizationService {     using ...

  3. crm高速开发之Entity

    我们在后台代码里面操作Entity的时候,基本上是这样写的: /* 创建者:菜刀居士的博客  * 创建日期:2014年07月5号  */ namespace Net.CRM.Entity {     ...

  4. JavaEE开发之SpringMVC中的自定义拦截器及异常处理

    上篇博客我们聊了<JavaEE开发之SpringMVC中的路由配置及参数传递详解>,本篇博客我们就聊一下自定义拦截器的实现.以及使用ModelAndView对象将Controller的值加 ...

  5. [Unity3D]Unity3D游戏开发之Lua与游戏的不解之缘终结篇:UniLua热更新全然解读

    ---------------------------------------------------------------------------------------------------- ...

  6. 微信公众号开发之VS远程调试

    目录 (一)微信公众号开发之VS远程调试 (二)微信公众号开发之基础梳理 (三)微信公众号开发之自动消息回复和自定义菜单 前言 微信公众平台消息接口的工作原理大概可以这样理解:从用户端到公众号端一个流 ...

  7. Android混合开发之WebViewJavascriptBridge实现JS与java安全交互

    前言: 为了加快开发效率,目前公司一些功能使用H5开发,这里难免会用到Js与Java函数互相调用的问题,这个Android是提供了原生支持的,不过存在安全隐患,今天我们来学习一种安全方式来满足Js与j ...

  8. Android混合开发之WebView与Javascript交互

    前言: 最近公司的App为了加快开发效率选择了一部分功能采用H5开发,从目前市面的大部分App来讲,大致分成Native App.Web App.Hybrid App三种方式,个人觉得目前以Hybri ...

  9. UWP开发之Template10实践二:拍照功能你合理使用了吗?(TempState临时目录问题)

    最近在忙Asp.Net MVC开发一直没空更新UWP这块,不过有时间的话还是需要将自己的经验和大家分享下,以求共同进步. 在上章[UWP开发之Template10实践:本地文件与照相机文件操作的MVV ...

随机推荐

  1. OpenCV配置使用版

    在VS2010环境中应用Opencv,网上找到了很多配置方法,但大多都是老版本的,很多新手面对最新版本的Opencv无从下手,就给新手童鞋写了这么一篇超级详细的配置攻略,贴上来共享.要强调一点的就是, ...

  2. 深入浅出—JAVA(1)

    1.基本概念 JAVA的工作方式 编写源代码文件--用编译器运行源代码(javac)--编译器会产出字节码--通过JAVA虚拟机读取与执行字节码(jvm). JAVA的程序结构 什么是源文件? 源文件 ...

  3. C语言之猜数字游戏

    猜数字游戏 猜数字游戏是以前功能机上的一款益智游戏,计算机会根据输入的位数随机分配一个符合要求的数据,计算机输出guess后便可以输入数字,注意数字间需要用空格或回车符加以区分,计算机会根据输入信息给 ...

  4. Qt之QNetworkInterface(查询网络接口),QHostInfo(查询主机IP)

    http://blog.csdn.net/u011012932/article/details/50775052 http://blog.csdn.net/u011012932/article/det ...

  5. 设计模式总结4--singleton pattern

    单例模式 保证每个类只有一个实例,并提供一个全局访问点 第一步 构造方法私有化第二步 公有化静态方法获取的实例 懒汉式  public class Bank{ private Bank(){} pri ...

  6. vs提示“当前不会命中断点,源代码与原始版本不同”的一种解决办法

    将出问题的cpp文件用notepad打开,另存为‘unicode’类型,覆盖源文件即可

  7. uva11021 - Tribles(概率)

    11021 - Tribles GRAVITATION, n.“The tendency of all bodies to approach one another with a strengthpr ...

  8. [置顶] C++ Pirate: Lambda vs Bind

    Lambda 与 Bind的性能比较 转载请说明出处:http://blog.csdn.net/cywosp/article/details/9379403 先让我们看看下面函数: template ...

  9. MVC自定义AuthorizeAttribute实现权限管理

    [转]MVC自定义AuthorizeAttribute实现权限管理 原文载自:小飞的DD http://www.cnblogs.com/feiDD/articles/2844447.html 网站的权 ...

  10. 如何使用notepad++搭配MinGW配置编译C/C++

    最经开始学C++了,平时学习不喜欢用IDE,一直以来都喜欢使用sublimetext写代码.所以在网上找了一下如何配置sublimetext编译C/C++.不过简单配置之后,只有输出,要想进行输出操作 ...