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

 * 创建日期: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. 关于MyEclipse启动时的插件启动(Maven4MyEclipse)

    在myEclipse的应用中有许多插件在开发的时候都用不到,那么,这些插件在启动myEclipse的时候一起启动的越少越好了 Maven4Myeclipse update 每当启动myEclipse的 ...

  2. 如何在Eclipse中配置Tomcat(免安装版)

    如何在Eclipse中配置Tomcat(免安装版) 2013-10-09 23:19wgelgrsh | 分类:JAVA相关 | 浏览642次 分享到:   2013-10-10 17:10提问者采纳 ...

  3. HTML5 事件

    下面的表格列出了可插入 HTML 5 元素中以定义事件行为的标准事件属性. Window 事件属性 - Window Event Attributes 表单事件 - Form Events 键盘事件 ...

  4. jQuery.form 中的 ajaxForm() 和 ajaxSubmit()

    官方例子  http://malsup.com/jquery/form/#ajaxForm官方API   http://malsup.com/jquery/form/#api中文API   http: ...

  5. javascript 关闭页面提示

    window.onbeforeunload = function (e) { e = e || window.event; // For IE and Firefox prior to version ...

  6. iOS 数据库第三方FMDB的简单使用

    一 FMDB的简单说明及介绍 FMDB的github地址 https://github.com/ccgus/fmdb FMDB是一款简洁的,易用的封装库,简单介绍一下FMDB的使用 在FMDB下载文件 ...

  7. Spout的实现步骤

    Spout的实现步骤: ·        对文件的改变进行分开的监听,并监视文件夹下有无新日志文件加入. ·        在数据得到了字段的说明后,将其转换成tuple. ·        声明Sp ...

  8. Apple Watch程序开发30分钟秒懂

    苹果公司Apple Watch智能手表正在备受追捧,迅速掌握Apple Watch的APP架构,环境搭建,及实例开发将会让开发者占尽先机.我赢职场全国首发,30分钟玩转Apple Watch应用开发实 ...

  9. E - Phone List(字典序,string类型使用)

    Description Given a list of phone numbers, determine if it is consistent in the sense that no number ...

  10. Basic DataList

    一,效果图. 二,源代码. <!DOCTYPE html><html><head> <meta charset="UTF-8"> & ...