Dynamic CRM 2013学习笔记(九)CrmFetchKit.js介绍:Fetchxml、多表联合查询, 批量更新

CrmFetchKit.js是一个跨浏览器的一个类库,允许通过JavaScript来执行fetch xml的查询,还可以实现批量更新,分页查询等。目前已支持Chrome 25, Firefox 19 和 IE9/10 .

它的最大优势是可以通过fetchxml 来查询,这样我们就可以实现真正的多表联合查询,虽然可以用OData终结点的$expand来进行多表的联合查询,但这种方式没办法过滤多表的条件,它只能过滤主表的条件。

下面来看下简单的多表查询的例子:

1.首先定义一个fetchxml:

  1: var fetchxml = [‘<fetch version="1.0" output-format="xml-platform" ‘,
  2:                     ‘mapping="logical" ‘,
  3:                     ‘returntotalrecordcount="true" >‘,
  4:                 ‘<entity name="new_floor_price">‘,
  5:                 ‘<attribute name="new_floor_priceid" />‘,
  6:                 ‘<order attribute="modifiedon" descending="true" />‘,
  7:                 ‘<filter type="and">‘,
  8:                     ‘<condition attribute="new_approval_status" operator="eq" value="3" />‘,
  9:                 ‘</filter>‘,
 10:                 ‘<link-entity name="new_fp_item" from="new_fp" to="new_floor_priceid" alias="ar">‘,
 11:                     ‘<attribute name="new_floor_price" />‘,
 12:                     ‘<filter type="and">‘,
 13:                     ‘<condition attribute="new_modelid" operator="eq" value="‘ + modelid + ‘" />‘,
 14:                     ‘</filter>‘,
 15:                 ‘</link-entity>‘,
 16:                 ‘</entity>‘,
 17:             ‘</fetch>‘].join(‘‘);

我一般先写好sql语句,然后在 http://sql2fetchxml.com/ 这里生成fetchxml 语句,再小改下参数就成了。

在上面的框里输入SQL 语句,点击 中间的Convert,就可以在下面的框里生成 Fetchxml的语句。

2. 调用很简单:

  1: CrmFetchKit.Fetch(fetchxml).then(function (results) {
  2:         if(results!=null)
  3:             setAttributeValue("new_floor_price", Number(results[0].getValue("ar.new_floor_price")));
  4:     }, onFetchError);

3. 错误处理:

  1: function onFetchError(xhr, status, errorThrown) {
  2:
  3:     var errormsg = $(xhr.responseXML).find(‘Message‘).text();
  4:
  5:     alert(‘CrmFetchKit-Error occured: ‘ +  errormsg);
  6: }

4. 另一种写法:

  1: // execute the query (async)
  2: CrmFetchKit.Fetch(fetchxml)
  3:   .fail(function(xhr, status, errorThrown){
  4:
  5:       // get the error-message
  6:       var msg = $(xhr.responseXML).find(‘Message‘).text();
  7:
  8:       alert(‘Error occured: ‘ + msg);
  9:   })
 10:   .done(function(results){
 11:
 12:       var contactid = null;
 13:
 14:       for( var i = 0, max = results.length; i < max; i++) {
 15:
 16:     contactid = results[i].getValue(‘contactid‘);
 17:
 18:     // Assign (async)
 19:     CrmFetchKit.Assign(contactid, ‘contact‘, bId);
 20:       }
 21:   });

这个示例中,还介绍了CrmFetchKit.Assign的用法

CrmFetchKit.Assign(contactid, ‘contact‘, bId);

这样就可以实现批量更新了

5. FetchMore 用法

  1: var fetchxml = [‘<fetch version="1.0" output-format="xml-platform" ‘,
  2:                         ‘mapping="logical" ‘,
  3:                         ‘returntotalrecordcount="true" ‘,
  4:                         ‘count="10">‘,
  5:                 ‘ <entity name="contact">‘,
  6:                 ‘ <attribute name="lastname" />‘,
  7:                 ‘ <attribute name="contactid" />‘,
  8:                 ‘ <filter type="and">‘,
  9:                 ‘ <condition attribute="lastname" operator="like" value="test%" />‘,
 10:                 ‘ </filter>‘,
 11:                 ‘ </entity>‘,
 12:                 ‘</fetch>‘].join(‘‘);
 13:
 14: CrmFetchKit.FetchMore(fetchxml).then(function (response) {
 15:
 16:     // 获取实体名
 17:     var entityname = response.entityName;
 18:
 19:     // fetchxml里必须设置 ‘returntotalrecordcount="true" ‘
 20:     var total = response.moreRecords;
 21:
 22:     // 取得实体的数组
 23:     var set = response.entities;
 24:
 25:     // 分页就需要这个 page-cookie
 26:     var pageCookie = response.pagingCookie;
 27:
 28:     ...
 29:
 30: }, onFetchError);

6. FetchAll用法:

  1: var fetchxml = [‘<fetch version="1.0" output-format="xml-platform" ‘,
  2:                         ‘mapping="logical" ‘,
  3:                         ‘count="10">‘,
  4:                 ‘ <entity name="contact">‘,
  5:                 ‘ <attribute name="lastname" />‘,
  6:                 ‘ <attribute name="contactid" />‘,
  7:                 ‘ <filter type="and">‘,
  8:                 ‘ <condition attribute="lastname" operator="like" value="test%" />‘,
  9:                 ‘ </filter>‘,
 10:                 ‘ </entity>‘,
 11:                 ‘</fetch>‘].join(‘‘);
 12:
 13: CrmFetchKit.FetchAll(fetchxml).then(function (entities) {
 14:
 15:     /* success-handler */
 16:
 17: }, onFetchError);

7. 下载地址

Download  CRM Fetch Kit

Dynamic CRM 2013学习笔记 系列汇总

时间: 2024-12-26 17:29:08

Dynamic CRM 2013学习笔记(九)CrmFetchKit.js介绍:Fetchxml、多表联合查询, 批量更新的相关文章

Dynamic CRM 2013学习笔记(十二)实现子表合计(汇总,求和)功能的通用插件

上一篇 Dynamic CRM 2013学习笔记(十一)利用Javascript实现子表合计(汇总,求和)功能 , 介绍了如何用js来实现子表合计功能,这种方法要求在各个表单上添加js方法,如果有很多实体要实现这个功能,有人觉得有点麻烦了,就不太喜欢这种方式,于是我写了一个通用的子表合计功能的通用插件,只用在注册插件时,填写不同的参数就可以实现这个功能了. 1. 首先看下效果: 2. 注册方法: 我们需要在子表上对create和update方法进行注册: 注册时要填写4个参数: 第一个参数是要被

Dynamic CRM 2013学习笔记(十八)根据主表状态用JS控制子表自定义按钮

有时要根据主表的审批状态来控制子表上的按钮要不要显示,比如我们有一个需求审批通过后就不能再上传文件了. 首先打开Visual Ribbon Editor, 如下图,我们可以利用Enable Rules –> CustomRule 用js来控制按钮是否显示:   js function: 首先用odata取出主表的状态,然后根据主表的状态来判断是否显示: var approvalStatus = null; function controlUpload(){ var marketingPlan =

Dynamic CRM 2013学习笔记(二十八)用JS动态设置字段的change事件、必填以及可见

我们知道通过界面设置字段的change事件,是否是必填,是否可见非常容易.但有时我们需要动态地根据某些条件来设置,这时有需要通过js来动态地控制了. 下面分别介绍如何用js来动态设置.   一.动态设置字段的change事件 // form on load event function onLoad() { init();   pageAttr.delivery_from.addOnChange(deliveryFromChange); pageAttr.type.addOnChange(typ

Dynamic CRM 2013学习笔记(十六)用JS控制Tab可见,可用

一个Form里经常会有好几个Tab,有时要根据一些条件设置哪些Tab可用,可见.下面就介绍下如何用JS对Tab进行控制. 1. 控制可见 function setTabVisableByName(tabName, flag) { var control = Xrm.Page.ui.tabs.get(tabName); control.setVisible(flag); } 这里flag是true或false 2. 控制可用 看了上面的可见代码,是不是以为可用也这么简单呢?其实我们把上面的setV

Dynamic CRM 2013学习笔记(二十三)CRM JS智能提示(CRM 相关的方法、属性以及页面字段),及发布前调试

我们知道在CRM的js文件里引用XrmPageTemplate.js后,就可以实现智能提示,但每个js文件都引用太麻烦了,其实可以利用vs的功能让每个js文件自动实现智能提示CRM的js: 另外,我们调试js,发布js文件也是比较繁琐的事情,最好的办法是全部调好,再发布上去,本文介绍用firefox + firebug + frame可以很方便地调试CRM js,全部调好后,再上传js,明显可以加快开发的速度. 1. 智能提示 CRM相关的方法属性的vs 里加上XrmPageTemplate.j

Dynamic CRM 2013学习笔记(二十三)CRM JS智能提示,及firebug frame调试

我们知道在CRM的js文件里引用XrmPageTemplate.js后,就可以实现智能提示,但每个js文件都引用太麻烦了,其实可以利用vs的功能让每个js文件自动实现智能提示CRM的js: 另外,我们调试js,发布js文件也是比较繁琐的事情,最好的办法是全部调好,再发布上去,本文介绍用firefox + firebug + frame可以很方便地调试CRM js,全部调好后,再上传js,明显可以加快开发的速度.   1. vs 里加上XrmPageTemplate.js: http://yunp

Dynamic CRM 2013学习笔记(二十九)reporting service 常见问题

在报表开发过程中,经常会遇到各种各样的问题,比如The report cannot be displayed. (rsProcessingAborted),一点有意义的提示都没有:再就是分页问题,经常我们想把一条记录放在一页,下一条记录另起一页,而不是紧连在上一条记录的后面:有时我们还会出现上传报表时报错:An error occurred while trying to add the report to Microsoft Dynamics CRM. Try adding the repor

Dynamic CRM 2013学习笔记(十九)自定义审批流 - 效果演示

CRM的项目,审批流是一个必须品.为了更方便灵活地使用.配置审批流,我们自定义了一整套审批流.首先来看下它的效果: 1. 审批模板 这是一个最简单的审批流,首先指定审批实体,及相关字段,再配置流程节点,这里只有5个节点,而且没有规则节点(后面会介绍):   接着就是对上面的流程节点配置关系,这里就指定流程节点的走向:   运行一段时间后,可以查看审批的实例:   2. 操作审批流 审批流模板创建完后,我们就可以进行审批活动了. 开始的状态是Draft,这时可以提交审批: 点击Submit 按钮后

Dynamic CRM 2013学习笔记(十七)JS读写各种类型字段方法及技巧

我们经常要对表单里各种类型的字段进行读取或赋值,下面列出各种类型的读写方法及注意事项: 1. lookup 类型 清空值 var state = Xrm.Page.getAttribute("new_state"); if (state != null) { Xrm.Page.getAttribute("new_state").setValue(null); } 读取值 var state = new Array(); state = Xrm.Page.getAtt