crm高速开发之OrganizationService
这是主要的开发模式:
/* 创建者:菜刀居士的博客
* 创建日期:2014年07月06号
*/
namespace Net.CRM.OrganizationService
{
using System;
using Microsoft.Xrm.Sdk;
using Microsoft.Xrm.Sdk.Query;
/// <summary>
/// 基本模式---OrganizationService
/// </summary>
public class OrganizationServiceDemo
{
/// <summary>
/// 查询
/// </summary>
public Entity Retrieve(IOrganizationService service, Entity en)
{
return service.Retrieve(en.LogicalName, en.Id, new ColumnSet("new_int", "new_string"));
}
/// <summary>
/// 删除
/// </summary>
public void Delete(IOrganizationService service, Entity en)
{
service.Delete(en.LogicalName, en.Id);
}
/// <summary>
/// 批量删除
/// </summary>
public void Delete(IOrganizationService service,EntityCollection ec)
{
if (ec != null && ec.Entities.Count > 0)
{
foreach(Entity en in ec.Entities)
{
service.Delete(en.LogicalName, en.Id);
}
}
}
/// <summary>
/// 更新int类型的字段
/// </summary>
public void UpdateInt(IOrganizationService service, Entity en)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName,Id = en.Id };
updateEn["new_int"] = 10;
service.Update(updateEn);
}
/// <summary>
/// 更新string类型的字段
/// </summary>
public void UpdateInt(IOrganizationService service, Entity en)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName, Id = en.Id };
updateEn["new_string"] = "abc";
service.Update(updateEn);
}
/// <summary>
/// 更新float类型的字段
/// </summary>
public void UpdateFloat(IOrganizationService service, Entity en)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName, Id = en.Id };
updateEn["new_float"] = 12.9;
service.Update(updateEn);
}
/// <summary>
/// 更新Money类型的字段
/// </summary>
public void UpdateMoney(IOrganizationService service, Entity en)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName, Id = en.Id };
updateEn["new_money"] = new Money(12);
service.Update(updateEn);
}
/// <summary>
/// 更新OptionSetValue类型的字段
/// </summary>
public void UpdateOptionSetValue(IOrganizationService service, Entity en)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName, Id = en.Id };
updateEn["new_optionsetvalue"] = new OptionSetValue(10);
service.Update(updateEn);
}
/// <summary>
/// 更新EntityReference类型的字段
/// </summary>
public void UpdateEntityReference(IOrganizationService service, Entity en)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName, Id = en.Id };
updateEn["new_account"] = new EntityReference() { LogicalName = "account",Id = Guid.NewGuid() };
service.Update(updateEn);
}
}
}
这是改进后的模式:
/* 创建者:菜刀居士的博客
* 创建日期:2014年07月06号
*/
namespace Net.CRM.OrganizationService
{
using System;
using Microsoft.Xrm.Sdk;
using Microsoft.Xrm.Sdk.Query;
/// <summary>
/// 高速开发---OrganizationService
/// </summary>
public class OrganizationServiceQuickDemo
{
/// <summary>
/// 查询
/// </summary>
public Entity Retrieve(IOrganizationService service, Entity en)
{
return service.Retrieve(en,"new_int", "new_string");
}
/// <summary>
/// 删除
/// </summary>
public void Delete(IOrganizationService service, Entity en)
{;
service.Delete(en);
}
/// <summary>
/// 批量删除
/// </summary>
public void Delete(IOrganizationService service, EntityCollection ec)
{
service.Delete(ec);
}
/// <summary>
/// 更新int类型的字段
/// </summary>
public void UpdateInt(IOrganizationService service, Entity en)
{
service.Update(en, "new_int", 10);
}
/// <summary>
/// 更新string类型的字段
/// </summary>
public void UpdateInt(IOrganizationService service, Entity en)
{
service.Update(en, "new_string", "abc");
}
/// <summary>
/// 更新float类型的字段
/// </summary>
public void UpdateFloat(IOrganizationService service, Entity en)
{
service.Update(en, "new_float", 12.9);
}
/// <summary>
/// 更新Money类型的字段
/// </summary>
public void UpdateMoney(IOrganizationService service, Entity en)
{
service.Update(en, "new_money", new Money(12));
}
/// <summary>
/// 更新OptionSetValue类型的字段
/// </summary>
public void UpdateOptionSetValue(IOrganizationService service, Entity en)
{
service.Update(en, "new_optionsetvalue", new OptionSetValue(10));
}
/// <summary>
/// 更新EntityReference类型的字段
/// </summary>
public void UpdateEntityReference(IOrganizationService service, Entity en)
{
service.Update(en, "new_account", new EntityReference() { LogicalName = "account", Id = Guid.NewGuid() });
}
}
/// <summary>
/// 扩展方法
/// </summary>
public static class EntityFunction
{
public static Entity Retrieve(this IOrganizationService service, Entity en,params string[] attrs)
{
return service.Retrieve(en.LogicalName, en.Id, new ColumnSet(attrs));
}
public static void Delete(this IOrganizationService service, Entity en)
{
service.Delete(en.LogicalName, en.Id);
}
public static void Delete(this IOrganizationService service, EntityCollection ec)
{
if (ec != null && ec.Entities.Count > 0)
{
foreach (Entity en in ec.Entities)
{
service.Delete(en.LogicalName, en.Id);
}
}
}
public static void Update<T>(this IOrganizationService service, Entity en, string name, T value)
{
Entity updateEn = new Entity() { LogicalName = en.LogicalName,Id = en.Id };
updateEn[name] = value;
service.Update(updateEn);
}
}
}
是不是开发快非常多。
一般的,假设你的项目不是非常大,时间足够充分。这个时候就没有必要用高速开发了
当你的项目非常大或者功能非常多,时间非常紧,这个时候高速开发就非常有必要了。
crm高速开发之OrganizationService的更多相关文章
- crm高速开发之QueryExpression
/* 创建者:菜刀居士的博客 * 创建日期:2014年07月06号 */ namespace Net.CRM.OrganizationService { using System; ...
- crm高速开发之EntityCollection
/* 创建者:菜刀居士的博客 * 创建日期:2014年07月07号 */ namespace Net.CRM.OrganizationService { using System; ...
- crm高速开发之Entity
我们在后台代码里面操作Entity的时候,基本上是这样写的: /* 创建者:菜刀居士的博客 * 创建日期:2014年07月5号 */ namespace Net.CRM.Entity { ...
- JavaEE开发之SpringMVC中的自定义拦截器及异常处理
上篇博客我们聊了<JavaEE开发之SpringMVC中的路由配置及参数传递详解>,本篇博客我们就聊一下自定义拦截器的实现.以及使用ModelAndView对象将Controller的值加 ...
- [Unity3D]Unity3D游戏开发之Lua与游戏的不解之缘终结篇:UniLua热更新全然解读
---------------------------------------------------------------------------------------------------- ...
- 微信公众号开发之VS远程调试
目录 (一)微信公众号开发之VS远程调试 (二)微信公众号开发之基础梳理 (三)微信公众号开发之自动消息回复和自定义菜单 前言 微信公众平台消息接口的工作原理大概可以这样理解:从用户端到公众号端一个流 ...
- Android混合开发之WebViewJavascriptBridge实现JS与java安全交互
前言: 为了加快开发效率,目前公司一些功能使用H5开发,这里难免会用到Js与Java函数互相调用的问题,这个Android是提供了原生支持的,不过存在安全隐患,今天我们来学习一种安全方式来满足Js与j ...
- Android混合开发之WebView与Javascript交互
前言: 最近公司的App为了加快开发效率选择了一部分功能采用H5开发,从目前市面的大部分App来讲,大致分成Native App.Web App.Hybrid App三种方式,个人觉得目前以Hybri ...
- UWP开发之Template10实践二:拍照功能你合理使用了吗?(TempState临时目录问题)
最近在忙Asp.Net MVC开发一直没空更新UWP这块,不过有时间的话还是需要将自己的经验和大家分享下,以求共同进步. 在上章[UWP开发之Template10实践:本地文件与照相机文件操作的MVV ...
随机推荐
- C#之纯数字判断
public bool isNaN(string temp) { ; i <temp.Length; i++) { byte tempByte = Convert.ToByte(temp[i]) ...
- wpf,vb,位图剪裁的方法
‘ 貌似WPF对GDI+不提供支持,要达到剪裁图像的方法,可以使用image.clip,’不过clip只是对图片的一个遮挡拦截效果,并不改变本身的图片资源.‘下面的代码提供了剪裁图片资源的方法. Di ...
- Reducing the Dimensionality of Data with Neural Networks:神经网络用于降维
原文链接:http://www.ncbi.nlm.nih.gov/pubmed/16873662/ G. E. Hinton* and R. R. Salakhutdinov . Science. ...
- 【sqli-labs】 less31 GET- Blind -Impidence mismatch -Having a WAF in front of web application (GET型基于盲注的带有WAF注入)
标题和less30一样 http://192.168.136.128/sqli-labs-master/Less-31/login.php?id=1&id=2" ")闭合的 ...
- js消息框
<script> function del(obj, id) { layer.confirm('是否要删除信息!', { btn: ['确定', '取消'] }, function (in ...
- Lost connection to MySQL server at 'reading authorization packet', system error: 0_Mysql
1.大多数时候设置"set global connect_timeout=60:"是可以解决问题的. 我们可以通过执行“SHOWSTATUS LIKE 'aborted%'”,可以 ...
- 集合运算(UNION)
表的加法 集合运算:就是满足统一规则的记录进行的加减等四则运算. 通过集合运算可以得到两张表中记录的集合或者公共记录的集合,又或者其中某张表中记录的集合. 集合运算符:用来进行集合的运算符. UNIO ...
- 复习MySQL④查询功能、连接方式、联合查询
用select语句查询: select〈目标列组〉 from〈数据源〉 [where〈元组选择条件〉] [group by〈分列组〉[having 〈组选择条件〉]] [order by〈排序列1〉〈 ...
- atcoder.keyence2019.contest E-Connecting Cities
真是道好题啊,当时怎么想都没想出来... 传送门 简述题意: 有n个点,每个点有一个权值Ai,连接i,j两个点的代价是 |i−j|×D+Ai+Aj 其中D是给定的常数,问把n个点联通的最小代价 1≤ ...
- 将项目上传到Github之使用git命令上传
1,先从GitHub网页上建立一个数据仓库 2,安装git 下载地址:https://www.git-scm.com/download/win 3,找到本地要上传的项目目录,右键点击Git Bash ...