1. 获取FetchXML因为FetchXML难以撰写,所以我们一般都是使用高级查找来生成FetchXML或者通过其他工具来生成。我这里在商机界面通过高级查找制作了一个新的视图,名称为 商机查询, 查询结果如下所示:

然后我将下载的Fetch XML放在桌面上,名称为 FetchXML.xml,其中的文本如下:

<fetch version="1.0" output-format="xml-platform" mapping="logical" distinct="false">

<entity name="opportunity">

<attribute name="name" />

<attribute name="customerid" />

<attribute name="estimatedvalue" />

<attribute name="opportunityid" />

<attribute name="estimatedclosedate" />

<order attribute="name" descending="false" />

<filter type="and">

<condition attribute="statecode" operator="eq" value="0" />

<condition attribute="ownerid" operator="eq-userid" />

</filter>

<link-entity name="account" from="accountid" to="customerid" alias="ac">

<attribute name="numberofemployees" />

<filter type="and">

<condition attribute="accountid" operator="not-null" />

</filter>

</link-entity>

</entity>

</fetch>

2.  新建报表项目。打开SQL Server Business Intelligence Development Studio,点击 文件 > 新建 > 项目,项目类型选择 商业智能项目 中的 报表服务器项目,为该项目命个名字。

3. 新建报表。在右边的解决方案资源管理器中的报表文件夹右击,选择 添加 >新建项,模板选择报表,我这里命名为 OpportunityReport.rdl ,然后点击添加按钮。
 

4.  添加数据源。在左边的 报表数据中 选择 数据源,右击,选择 添加数据源,名称我输入CRM,嵌入链接的类型我选择 Microsoft Dynamics CRM Fetch,连接字符串的输入格式是:将组织的url,比如http://crmserver:5555/DefaultOrg 中的倒数第一个斜线换成分号。然后在数据源中的凭据中选择 使用此用户名和密码,然后输入用户名和密码。

 

5.    添加数据集。右击上一步骤添加的数据源,选择 添加数据集 ,在查询下面的文本框中输入我们之前拿到的FetchXML,然后点击 刷新字段 按钮,然后点击 确定 按钮关闭该对话框。你会看到数据集中出来了不少字段。

 

6. 制作报表。打开报表的工具箱,将一个表拖动到设计界面,然后将要显示的字段,比如name,customerid,estimatedvalueValue,estimatedcloseddateValue,ac_numberofemployeesValue 拉到表的列中,并稍微下设置格式,更改列标题。完成后效果如下图所示,然后点击设计旁边的预览可以看到效果。然后点击全部保存将它保存下来。注意,拉到报表中的列一般要用自动加上Value的那些列。

如果要格式化请参考文章 Personalizing Reports for Microsoft Dynamics CRM Online 。

CRM Reporting Undocumented Feature Uncovered

 

 7.  开启报表的预筛选功能。右击报表数据中的参数文件夹,选择 添加参数,名称设置为 CRM_FilteredOpportunity ,(ps:对于CRM中的报表,以CRM_开头的参数是会自动变成隐藏参数,因为本查询主要实体是Opportunity,所以命名为CRM_FilteredOpportunity)选择参数可见性设置为 隐藏 。在默认值中指定默认值,指定的默认值为 <fetch version="1.0" output-format="xml-platform" mapping="logical" distinct="false"><entity name="opportunity"><all-attributes /></entity></fetch> 。然后点击确定关闭这个窗口。

 

 8.  更改Dataset增加一个参数。然后双击 DataSet1 ,在参数中增加一个参数,参数名称设置为 CRM_FilteredOpportunity ,参数值设置为[@CRM_FilteredOpportunity] ,然后点击 查询 ,修改查询的文本,主要是对主实体opportunity增加属性 enableprefiltering="1" prefilterparametername="CRM_FilteredOpportunity" ,如后图所示。

 

 9.   上传报表。导航到 设置 > 自定义 > 自定义项 > 自定义系统,选择 新建 > 报表,报表类型选择现有文件,然后点击浏览按钮选择报表文件,我这里是OpportunityReport.rdl,起个名字,选择类别为销售报表,相关记录类型选择 商机,显示于选择你想要显示的地方,然后点击保存,在点击 发布所有自定义项。PS:也可以在 工作区 > 我的工作 >报表 新建报表,这里新建则不需要发布,方便。

 
 

10.  测试报表。导航到 销售 > 商机,点击 运行报表 > 我的商机报表,在弹出的页面中做合适的选择后,点击 运行报表 按钮,一会儿报表就运行出来了。

 
 
 
 
引用地址:http://luoyong0201.blog.163.com/blog/static/1129305201310298221728/
注明:除了安装Business Intelligency Development Studio (sql server 2012版本,这个工具是包括在SQL Server Data Tools这个功能中了)外,制作该种类型的报表,需要安装Report Authoring Extension。

MSCRM中报表开发二:创建基于FetchXML报表的更多相关文章

  1. 六、K3 WISE 开发插件《直接SQL报表开发新手指导 - BOM成本报表》

    ======================== 目录: 1.直接SQL报表 ======================== 1.直接SQL报表 以BOM成本报表为例,在销售模块部署,需要购买[金蝶 ...

  2. MSCRM中报表开发一:创建基于SQL报表

    1.       新建报表项目.打开SQL Server Business Intelligence Development Studio,点击 文件 > 新建 > 项目,项目类型选择 商 ...

  3. Win10 IoT C#开发 2 - 创建基于XAML的UI程序 及 应用的三种部署方法

    Windows 10 IoT Core 是微软针对物联网市场的一个重要产品,与以往的Windows版本不同,是为物联网设备专门设计的,硬件也不仅仅限于x86架构,同时可以在ARM架构上运行. 上一章我 ...

  4. debian下为arm开发板创建基于debian或emdebian的根文件系统

    Debian系统本身包含对arm的支持,其包含的软件包最多,但是最终的文件系统要大一些. emdebian 是一个非常好用的嵌入式linux操作系统,其基于debian的特点对于熟悉debian系统的 ...

  5. ActiveReport系列报表开发随笔收集

    转自:博客园 http://www.cnblogs.com/dahuzizyd/archive/2007/04/11/ActiveReport_All.html 使用ActiveReport for ...

  6. ReportingServies——SQLServer报表开发综合实例

    如果我们安装了sqlserver2008 R2,将会自动安装一个报表开发工具 不要以为此报表开发工具只适合于sqlserver2008,其实在sqlserver2012中也是支持的,事实上我现在项目中 ...

  7. Qlik报表开发见解

    因为项目需要,最近去做了Qlik Sense报表开发,学习了Qlik报表的开发方法和一些基础的开发模式,以下是我对Qlik报表开发的一些见解,个人水平有限,欢迎大神指导. 1.Qlik Sense的函 ...

  8. 在DevExpress程序中使用条形码二维码控件,以及进行报表打印处理

    在很多业务系统里面,越来越多涉及到条形码.二维码的应用了,不管在Web界面还是WInform界面都需要处理很多物料相关的操作,甚至很多企业为了减少录入错误操作,为每个设备进行条形码.二维码的标签,直接 ...

  9. 微软BI 之SSRS 系列 - 在 Cube 中通过 MDX 查询实现基于父子递归关系的汇总报表

    之前我写了一篇在 SSRS 开发中处理这种父子关系的汇总与聚合的文章 (SSRS 系列 - 使用分组 Group 属性实现基于父子递归关系的汇总报表),示例中的查询是基于 SQL Server 关系型 ...

随机推荐

  1. 发现一个好玩的东西 Web Scraper

    是一个 Chrome 的扩展程序,机智的小爬虫

  2. JavaScript实现LUHN算法验证银行卡号有效性

    一般验证银行卡有效性用到一种叫做LUHN的算法,简介请参考这篇博客:基于Luhn算法的银行卡卡号的格式校验 注意: 1.LUHN算法只是能校验卡号是否有效,并不能校验卡号和用户名是否一致. 2.如果有 ...

  3. Android网络请求与数据解析,使用Gson和GsonFormat解析复杂Json数据

    版权声明:未经博主允许不得转载 一:简介 [达叔有道]软件技术人员,时代作者,从 Android 到全栈之路,我相信你也可以!阅读他的文章,会上瘾!You and me, we are family ...

  4. setAttribute的浏览器兼容性(转)

    1.element要用getElementById or ByTagName来得到, 2.setAttribute("class", vName)中class是指改变"c ...

  5. 和嗲妹妹面试python,是种什么体验?

    这次给大家讲讲我2年前去爱奇艺面试高级运维开发岗位的经历,希望对大家带来一些帮助. 公众号「Python专栏」后台回复:自动化运维平台,获取整套自动化运维平台的源代码 聊骚阶段 嗲妹妹:你好,我是爱奇 ...

  6. 金三银四季来了!Java 面试题大放送,能答对70%就去BATJTMD试试~

    摘要: 2019,相对往年我们会发现今年猎头电话少了,大部分企业年终奖缩水,加薪幅度也不如往年,选择好offer就要趁早,现在开始准备吧,刷一波Java面试题,能回答70%就去BATJTMD大胆试试~ ...

  7. 写在19年初的后端社招面试经历(两年经验): 蚂蚁 头条 PingCAP

    去年(18年)年底想出来看看机会,最后很幸运地拿到了 PingCAP,今日头条的 offer 以及蚂蚁金服的口头 offer.想着可以总结一下经验,分享一下自己这一段"骑驴找马"过 ...

  8. Visual Studio For MacOS 踩坑记(二)

    Visual Studio For MacOS安装安卓SDK. 系统默认安装了安卓6.0  API23的SDK.  但是我需要安卓7.0的,API24.  遂安装. SDK可以下载成功,但是用Visu ...

  9. 判断URL中的中文参数是GB2312还是Utf-8编码

    如两个URL字符串: &q=%E8%A3%99%E5%AD%90&style=grid&seller_type=taobao &q=%CE%D0%C2%D6%D4%F6 ...

  10. 关于 Spring Security 5 默认使用 Password Hash 算法

    账户密码存储的安全性是一个很老的话题,但还是会频频发生,一般的做法是 SHA256(userInputpwd+globalsalt+usersalt) 并设置密码时时要求长度与大小写组合,一般这样设计 ...