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

 * 创建日期: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. 数据层使用DBHelper.dll来减少工作量

    目前在需求确定了以后进行开发的步骤一般是这样的:建立数据表,建立model,构建数据操作层,最后在页面中进行调用.关于数据操作层,因为大量的操作都集中在增加.更新.删除等简易操作,而我之前的写法是每次 ...

  2. NSString 用法大全。

    一.NSString 创建字符串.  NSString *astring = @"This is a String!"; 创建空字符串,给予赋值.  NSString *astri ...

  3. C和指针---读书笔记。

    C和指针---读书笔记.1,unsigned int  声明无符号int类型 默认是 singned,即此整数类型包括正负数.也可用于long上.说明符有 unsigned signed short ...

  4. octopress command memo

    1 rake new_post rake new_post[title]           # Begin a new post in source/_posts 2 rake preview ht ...

  5. 关于map

    java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMap. Map主要用于存储健值对, ...

  6. MySQL server has gone away 解决方法

    应用程序(比如PHP)长时间的执行批量的MYSQL语句.执行一个SQL,但SQL语句过大或者语句中含有BLOB或者longblob字段.比如,图片数据的处理.都容易引起MySQL server has ...

  7. ThinkPHP - 查询语句

    public function index(){ // + ----------------------- // | 查询语句 // + ----------------------- // 实例化模 ...

  8. BZOJ 1648: [Usaco2006 Dec]Cow Picnic 奶牛野餐( dfs )

    直接从每个奶牛所在的farm dfs , 然后算一下.. ----------------------------------------------------------------------- ...

  9. struts2上传图片

    在WEB-INF下新建一个content目录,建立一个upload.jsp <%@ page contentType="text/html; charset=UTF-8" l ...

  10. MyEclipse8.5 中安装Spket插件

    MyEclipse8.5 中安装Spket插件 安装: 1. Myeclipse8.5安装和以前低版本有些不同(没有software updates). 点击help->Myeclipse Co ...