AX2012/D365 SSRS报表开发
大家好,好久没有做SSRS报表了,近期刚好有做2张,就整理起来供初学者参考。
AX中SSRS报表开发的框架,父类非常多,这里跟大家简单分享2种比较常用的场景供大家使用。
1.简单的过滤字段,无特殊过滤lookup需要重载,只需要通过扩展类型实现下拉数据,无过滤条件信息联动需求;
即可以使用Contract直接作为参数,DP作为数据源,使用Controller进行调用。
以下代码为核心框架代码,边沿代码已拿掉。
临时表Tmp使用表类型:TempDB:
Controller类:
{
public static ProdCostAnalysisController construct()
{
return new ProdCostAnalysisController();
}
{
ProdCostAnalysisController controller = ProdCostAnalysisController::construct();
controller.parmReportName(ssrsReportStr(ProductionCostAnalysis, Report));
controller.parmArgs(_args);
controller.startOperation();
}
class ProdCostAnalysisContract
{
TransDate dateFrom;
TransDate dateTo;
TransDate parmDateFrom(TransDate _dateFrom = dateFrom)
{
dateFrom = _dateFrom;
}
TransDate parmDateTo(TransDate _dateTo = dateTo)
{
dateTo = _dateTo;
}
SRSReportParameterAttribute(classStr(ProdCostAnalysisContract)),
SRSReportQueryAttribute(queryStr(ProdCostAnalysis))
]
class ProdCostAnalysisDP extends SrsReportDataProviderPreProcessTempDB
{
ProdCostAnalysisTmp prodCostAnalysisTmp;
CostAnalysisCostGroupTmp costAnalysisCostGroupTmp;
BOMCostGroup bomCostGroup;
{
}
public ProdCostAnalysisTmp getProdCostAnalysisTmp()
{
select * from prodCostAnalysisTmp;
}
public CostAnalysisCostGroupTmp getCostAnalysisCostGroupTmp()
{
select * from costAnalysisCostGroupTmp;
}
{
ProdCostAnalysisContract rdpContract;
TransDate dateFrom;
TransDate dateTo;
dateFrom = rdpContract.parmDateFrom();
dateTo = rdpContract.parmDateTo();
QueryBuildDataSource qbds = query.dataSourceTable(tableNum(ProdTable));
QueryBuildRange qbr = qbds.addRange(fieldNum(ProdTable, SchedEnd));
QueryRun queryRun = new QueryRun(query);
{
ProdTable prodTable = queryRun.get(tableNum(ProdTable));
InventDim inventDim = queryRun.get(tableNum(InventDim));
this.createReportData(prodTable, inventDim);
}
}

2.报表查询条件需要重载下拉,需要有联动处理过滤条件;
即可以使用Contract作为参数,绑定UIUIBuilder类,DP作为数据源,使用Controller进行调用。
以下代码为核心框架代码,边沿代码已拿掉。
临时表Tmp使用表类型:TempDB:
Controller类:
{
PrintBarCodeContract contract;
{
PrintBarcodeController controller = new PrintBarcodeController();
controller.parmArgs(_args);
controller.parmReportName(ssrsReportStr(PrintBarCode, Report));
controller.parmShowDialog(true);
controller.startOperation();
}
{
if (!this.parmArgs())
{
throw error(strFmt("@GLS221124", this.parmReportName()));
}
super();
{
switch (this.parmArgs().dataset())
{
case tableNum(WMSJournalTrans):
WMSJournalTrans wmsJournalTrans = this.parmArgs().record() as WMSJournalTrans;
contract = this.parmReportContract().parmRdpContract() as PrintBarCodeContract;
contract.parmSourceTableId(wmsJournalTrans.TableId);
contract.parmSourceRecId(wmsJournalTrans.RecId);
break;
ProdJournalBOM prodJournalBOM = this.parmArgs().record() as ProdJournalBOM;
contract = this.parmReportContract().parmRdpContract() as PrintBarCodeContract;
contract.parmSourceTableId(prodJournalBOM.TableId);
contract.parmSourceRecId(prodJournalBOM.RecId);
break;
}
}
}
DataContractAttribute,
SysOperationContractProcessingAttribute(classStr(PrintBarCodeUIBuilder), SysOperationDataContractProcessingMode::CreateUIBuilderForRootContractOnly)
]
class PrintBarCodeContract
{
TableId sourceTableId;
RecId sourceRecId;
Integer packagingQty, boxQty, innerQty;
[
DataMemberAttribute('SourceRecId'),
SysOperationDisplayOrderAttribute('4')
public RecId parmSourceRecId(RecId _sourceRecId = sourceRecId)
{
sourceRecId = _sourceRecId;
}
DataMemberAttribute('SourceTableId'),
SysOperationDisplayOrderAttribute('5')
]
public TableId parmSourceTableId(TableId _sourceTableId = sourceTableId)
{
sourceTableId = _sourceTableId;
}
DataMemberAttribute('PackagingQty'),
SysOperationDisplayOrderAttribute('1'),
SysOperationLabelAttribute(literalStr("@SYS50772"))
]
public Integer parmPackagingQty(Integer _packagingQty = packagingQty)
{
packagingQty = _packagingQty;
}
DataMemberAttribute('BoxQty'),
SysOperationDisplayOrderAttribute('2'),
SysOperationLabelAttribute(literalStr("@KKC0338"))
]
public Integer parmBoxQty(Integer _boxQty = boxQty)
{
boxQty = _boxQty;
}
DataMemberAttribute('InnerQty'),
SysOperationDisplayOrderAttribute('3'),
SysOperationLabelAttribute(literalStr("@SYS50777"))
]
public Integer parmInnerQty(Integer _innerQty = innerQty)
{
innerQty = _innerQty;
}
{
DialogField dialogpackagingQty;
DialogField dialogBoxQty;
DialogField dialogInnerQty, dialogTableId, dialogRecId;
PrintBarCodeContract contract;
WMSJournalTrans wmsJournalTrans;
{
contract = this.dataContractObject() as PrintBarCodeContract;
super();
dialogTableId.visible(false);
dialogRecId = this.bindInfo().getDialogField(contract, methodstr(PrintBarCodeContract, parmSourceRecId));
dialogRecId.visible(false);
dialogpackagingQty = this.bindInfo().getDialogField(contract, methodstr(PrintBarCodeContract, parmPackagingQty));
dialogBoxQty = this.bindInfo().getDialogField(contract, methodstr(PrintBarCodeContract, parmBoxQty));
dialogBoxQty.allowEdit(false);
dialogBoxQty.value(0);
dialogInnerQty = this.bindInfo().getDialogField(contract, methodstr(PrintBarCodeContract, parmInnerQty));
dialogpackagingQty.registerOverrideMethod(methodstr(FormIntControl, modified), methodstr(PrintBarCodeUIBuilder, packagingQtyModified), this);
if (contract.parmSourceTableId() == tableNum(WMSJournalTrans))
{
dialogInnerQty.visible(false);
select firstonly wmsJournalTrans
where wmsJournalTrans.RecId == contract.parmSourceRecId();
dialogpackagingQty.value(InventTable::find(wmsJournalTrans.itemId).TaxPackagingQty);
if (wmsJournalTrans.qty &&
dialogpackagingQty.value())
{
dialogBoxQty.value(roundUp(wmsJournalTrans.qty / dialogpackagingQty.value(), 1));
}
}
if (contract.parmSourceTableId() == tableNum(ProdJournalBOM))
{
dialogpackagingQty.visible(false);
dialogBoxQty.visible(false);
ProdJournalBOM prodJournalBOM = ProdJournalBOM::findRecId(contract.parmSourceRecId());
dialogInnerQty.value(prodJournalBOM.BOMConsump);
}
}
{
if (_dialogpackagingQty.modified() && _dialogpackagingQty.value())
{
dialogBoxQty.value(roundUp(wmsJournalTrans.qty / dialogpackagingQty.value(), 1));
}
if (!_dialogpackagingQty.value())
{
dialogBoxQty.value(0);
}
return true;
}
SRSReportParameterAttribute(classStr(PrintBarCodeContract))
]
class PrintBarCodeDP extends SrsReportDataProviderPreProcessTempDB
{
BarcodeTmp barCodePrintTmp;
PrintBarCodeContract contract;
public BarcodeTmp getBarcodeTmp()
{
select * from barCodePrintTmp;
}
public void processReport()
{
int i;
contract = this.parmDataContract() as PrintBarCodeContract;
{
WMSJournalTrans wmsJournalTrans;
where wmsJournalTrans.RecId == contract.parmSourceRecId();
{
Barcode barcode = Barcode::construct(BarcodeType::Code128);
InventDim inventDim = wmsJournalTrans.inventDim();
barcodePrintTmp.clear();
barcodePrintTmp.linenum = i;
barcodePrintTmp.BarCode = "*" + wmsJournalTrans.ItemId +"*";
barcode.string(true, barcodePrintTmp.BarCode);
barcode.encode();
barcodePrintTmp.BarCodeString = barcode.barcodeStr();
barcodePrintTmp.InventBatchId = inventDim.InventBatchId;
barcodePrintTmp.InventSerialId = inventDim.inventSerialId;
barcodePrintTmp.InventColorId = inventDim.InventColorId;
if (barcodePrintTmp.InventColorId)
{
barcodePrintTmp.ColorIdVisable = 1;
}
else
{
barcodePrintTmp.ColorIdVisable = 0;
}
barcodePrintTmp.UnitId = InventTableModule::find(wmsJournalTrans.itemId, ModuleInventPurchSales::Invent).UnitId;
if ((wmsJournalTrans.qty mod contract.parmPackagingQty()) == 0)
{
barcodePrintTmp.InnerBoxNum = contract.parmPackagingQty();
}
else
{
barcodePrintTmp.InnerBoxNum = (i < contract.parmBoxQty()) ? contract.parmPackagingQty() : (wmsJournalTrans.qty mod contract.parmPackagingQty());
}
barcodePrintTmp.InnerBoxQtyUnitId = strFmt('%1 %2', int2Str(barcodePrintTmp.InnerBoxNum), barcodePrintTmp.UnitId);
barcodePrintTmp.ItemName = InventTable::find(wmsJournalTrans.itemId).itemName();
barcodePrintTmp.ItemGroupName = InventItemGroup::find(wmsJournalTrans.inventTable().itemGroupId()).Name;
barcodePrintTmp.insert();
}
}
if (contract.parmSourceTableId() == tableNum(ProdJournalBOM))
{
ProdJournalBOM prodJournalBOM = ProdJournalBOM::findRecId(contract.parmSourceRecId());
Barcode barcode = Barcode::construct(BarcodeType::Code128);
InventDim inventDim = prodJournalBOM.inventDim();
barcodePrintTmp.clear();
barcodePrintTmp.linenum = 1;
barcodePrintTmp.BarCode = "*" + prodJournalBOM.ItemId +"*";
barcode.string(true, barcodePrintTmp.BarCode);
barcode.encode();
barcodePrintTmp.BarCodeString = barcode.barcodeStr();
barcodePrintTmp.InventBatchId = inventDim.InventBatchId;
barcodePrintTmp.InventSerialId = inventDim.inventSerialId;
barcodePrintTmp.InventColorId = inventDim.InventColorId;
if (barcodePrintTmp.InventColorId)
{
barcodePrintTmp.ColorIdVisable = 1;
}
else
{
barcodePrintTmp.ColorIdVisable = 0;
}
barcodePrintTmp.UnitId = prodJournalBOM.BOMUnitId;
barcodePrintTmp.InnerBoxNum = contract.parmInnerQty();
barcodePrintTmp.InnerBoxQtyUnitId = strFmt('%1 %2', int2Str(barcodePrintTmp.InnerBoxNum), barcodePrintTmp.UnitId);
barcodePrintTmp.ItemName = InventTable::find(prodJournalBOM.itemId).itemName();
barcodePrintTmp.ItemGroupName = InventItemGroup::find(prodJournalBOM.inventTable().itemGroupId()).Name;
barcodePrintTmp.insert();
}
}


3.报表开发中经常需要多选传值,从Controller传值到DP类,这里也介绍一种简单的方法;
3.1在Controller类的方法prePromptModifyContract中加入如下代码:
SRSReportRunPermission SRSRRPermission;
Contract.parmTmpTableDataRecId(SRSTmpTblMarshaller::sendTmpTblToDataProvider(BarCodeTmp));(合约类增加这个方法)
(
[
DataMemberAttribute('TmpTblDataRecId')
]
public RecId parmTmpTableDataRecId(RecId _tmpTableDataRecId = tmpTableDataRecId)
{
tmpTableDataRecId = _tmpTableDataRecId;
return tmpTableDataRecId;
}
)
SRSTmpTblMarshaller::sendTmpTblToDataProvider(BarCodeTmp);
CodeAccessPermission::revertAssert();
3.2在DP类中加入如下代码获取数据对象集合:
new SRSReportRunPermission().assert();
BarCodeTmp = SRSTmpTblMarshaller::getTmpTbl(contract.parmTmpTableDataRecId());
SRSTmpTblMarshaller::deleteTmpTblData(contract.parmTmpTableDataRecId());
CodeAccessPermission::revertAssert();
AX2012/D365 SSRS报表开发的更多相关文章
- [AX2012]在SSRS报表中获取从Menuitem传入的记录
在较早版本的AX中我们运行一个报表时会用到类RunBaseReport,从它扩展一个子类,再由它运行报表,一个典型的Axapta3中的例子: class ReportProdInfo extends ...
- SSRS 报表开发小技巧
说明: 开发工具为: SQL Server Data Tools (英文版) 开发环境为: SQL Server 2012 (英文版) 一. 饼图数据外部显示 首先我们来看3张效果图: 内部 ...
- WIN8 Metro UI 风格下的微软报表开发与设计 Metro UI SSRS - BIWORK
开篇介绍 作为 BI 系统前端展现的报表,其重要性不言而喻,我们对于一个好的报表的要求也无非主要包含以下几点: 1. 数据完整和正确,数据质量没有问题 2. 友好的清晰的界面,整洁美观,有得体的格式 ...
- 【Reporting Services 报表开发】— 交互式报表
我们知道,界面是人与系统间的对话方式,当使用者面对的是冷冰冰的界面,不但会造成使用者对于系统的热情减低,也会因为不便而产生诸多抱怨.尤其像报表时企业内几乎每日都会使用到的工具,因此,如何让使用者可以再 ...
- [AX2012 R3]在SSRS报表中使用QR二维码
AX2012是自带生成QR二维码的类,可以很方便的用在SSRS报表中,下面演示如何在RDP的报表中使用二维码,首先从定义临时表开始: 字段URL是要用于二维码的字符串,QrCode是container ...
- Dynamics AX 2012 R2 SSRS报表在VS2010中预览没有数据
今天,Reinhard 在VS中制作SSRS报表,预览的时候发现显示不出数据. 仔细检查了数据处理环节和临时表里的数据,都发现没有问题. 用同事的账号登陆同样的开发环境,发现他的账号可以在VS中预览到 ...
- 【Reporting Services 报表开发】— 表达式
一.常用的SSRS原始函数可以打开文本框的表达式中看到,如图1 图1 如下为SSRS中设计报表时常用的运算函数: 运算符/函数 说明 + 前后位数字则为加法,前后为字符串则为链接符号 - 数值减法 * ...
- [译]SSRS 报表版本控制
问题 如今商务智能应用广泛,对我们的商业愈加重要. 对新报表和的各种需求不断攀升. 自 SQL Server 2008 R2的 Reporting Services (SSRS) 开始,微软视图为减轻 ...
- SSRS报表服务随笔(rdl报表服务)-创建一个简单的报表
这段时间一直在敲rdl报表,在国内的不这么留在,在国外的话,还是挺流行的,国内的话,这方面的资料很少很少,也踏过不少坑 先从SSRS了解起,SSRS全称 SQL Server Reporting Se ...
随机推荐
- F5 BIG-IP LTM负载均衡策略
standard 模式 可以很好的 防止 DDOS攻击 轮询设置是在POOL 中设置 按比率设置是在Node节点中设置
- UMLet的使用与类图的设计
本实验是为后续实验做准备的.在本书中,各个程序实例都要画类图,所以读者必须掌握用某种UML建模工具来画类图,本书选择 UMLet 作为 UML 的建模工具.实验目的本实验的主要目的如下. 理解类的基本 ...
- worship|spurs|drowns out|frauds|expell|spray with|deposit|moist|gave a sigh
to have or show a strong feeling of respect and admiration for God or a god 敬奉,崇拜,信仰(上帝或神) On the is ...
- markdown常见用法
命令 生成目录 [TOC] 插入标题 # 一级标题## 二级标题### 三级标题#### 四级标题##### 五级标题###### 六季标题 插入shell 开头:```shell 结尾 ...
- 深入理解 C/C++ 数组和指针
本文转载自CSDN@WalkingInTheWind,原文链接:https://blog.csdn.net/luckyxiaoqiang/article/details/7044380 C语言中数组和 ...
- JavaScript中对象数组去重方法
在一次对后端返回的对象数组的操作时想通过indexOf()或者includes()的方法来实现对对象数组的去重但是行不通,因为用indexOf()返回的都是-1,一下记录两种对象数组(更具指定属性)去 ...
- SQL逻辑查询处理顺序特别提醒
我们知道在SQL语句中,第一个被处理的子句式FROM,而不是第一出现的SELECT.这就是SQL不同于其他编程语言的最明显特征之一,以下先看一下SQL查询处理的步骤序号: (8) SELECT (9) ...
- Python知识点总结及其介绍链接
Python 弱引用(不会增加引用计数的引用,可以用来做对象缓存,避免循环引用导致内存无法回收):http://python.jobbole.com/85431/ from future import ...
- 谈谈从事IT测试行业的我,对于买房买车有什么样的感受
周边测试同事,开发同事买?买?的比较多, 偶尔大家话题中也会谈起这个. 毕竟工作.衣.食.住.行和我们每个IT从业者息息相关, 大家有着相同或相似的感受与经验. - 前公司 以前公司测试经理 10年从 ...
- Android 绘制中国地图
最近的版本有这样一个需求: 有 3 个要素: 中国地图 高亮省区 中心显示数字 面对这样一个需求,该如何实现呢? 高德地图 因为项目是基于高德地图来做的,所以很自然而然的想到了高德.但是当查阅高德地图 ...