在QBFC中一次可以从MsgSetRequest
添加/返回的报告查询数量是否受到限制?
我当前正在创建多个GeneralSummaryReportQuery
并将其添加到MsgSetRequest
(例如30),但是在执行请求之后,事情似乎出错了。我可以看到ResponseList
的大小正确,但是在列表中的前10个Response
之后,其余响应的状态代码更改为3320
,这表明该报告无法被生成。如果我使用相同的过滤器运行相同的报告,并向请求中添加了更少的查询,则报告将成功生成。
我浏览了QBSDK ProGuide一书,并进行了一些谷歌搜索,但我没有在网上看到任何提及此限制的信息。
以下是一些值得说明的示例代码:
IMsgSetRequest msgSetReq = sessionManager.CreateMsgSetRequest("US", 13, 0);
msgSetReq.Attributes.OnError = ENRqOnError.roeContinue;
foreach (string key in traversalOrder) {
IGeneralSummaryReportQuery summaryReportQuery = msgSetReq.AppendGeneralSummaryReportQueryRq();
summaryReportQuery.GeneralSummaryReportType.SetValue(ENGeneralSummaryReportType.gsrtProfitAndLossByJob);
summaryReportQuery.ReportEntityFilter.ORReportEntityFilter.FullNameList.Add(tableData[key].FullName);
}
//Now do all the queries
IMsgSetResponse msgSetResp = sessionManager.DoRequests(msgSetReq);
for (int k = 0; k < msgSetResp.ResponseList.Count; k++) {
IResponse resp = msgSetResp.ResponseList.GetAt(k);
if (resp.StatusCode >= 0 && resp.Detail != null) {
//do stuff -- this only enters in the first 10 Responses in the ResponseList
}
}
我启用了详细日志记录并查看了日志-报告请求正按预期格式以XML格式生成:
<GeneralSummaryReportQueryRq requestID = "9">
<GeneralSummaryReportType>ProfitAndLossByJob</GeneralSummaryReportType>
<ReportEntityFilter>
<FullName>TestGuy9</FullName>
</ReportEntityFilter>
</GeneralSummaryReportQueryRq>
<GeneralSummaryReportQueryRq requestID = "10">
<GeneralSummaryReportType>ProfitAndLossByJob</GeneralSummaryReportType>
<ReportEntityFilter>
<FullName>TestGuy10</FullName>
</ReportEntityFilter>
</GeneralSummaryReportQueryRq>
但是,在日志的更下方,我们看到报告生成失败,但是没有说明原因。对于接下来的所有剩余报告请求,此操作继续进行。
20190919.103424 I 16112 QBSDKMsgSetHandler QUERY: General Summary Report
20190919.103424 D 16112 ReportStorage::DoQuery Processing request for report: ProfitAndLossByJob
20190919.103424 D 16112 ReportStorage::DoQuery Setting report type
20190919.103424 D 16112 ReportStorage::DoQuery Initializing report defaults
20190919.103424 D 16112 ReportStorage::DoQuery 1st override of defaults
20190919.103424 D 16112 ReportStorage::DoQuery Initializing report
20190919.103424 D 16112 ReportStorage::DoQuery 2nd override of defaults
20190919.103424 D 16112 ReportStorage::DoQuery Generating the report
20190919.103425 D 16112 ReportStorage::DoQuery Building the response
20190919.103425 D 16112 ReportHandler::BuildTheRetObject Number of column rows: 2
20190919.103425 D 16112 ReportStorage::DoQuery Finished building the response
20190919.103425 I 16112 QBSDKMsgSetHandler Request 9 completed successfully.
20190919.103425 I 16112 QBSDKMsgSetHandler QUERY: General Summary Report
20190919.103425 D 16112 ReportStorage::DoQuery Processing request for report: ProfitAndLossByJob
20190919.103425 D 16112 ReportStorage::DoQuery Setting report type
20190919.103425 D 16112 ReportStorage::DoQuery Initializing report defaults
20190919.103425 D 16112 ReportStorage::DoQuery 1st override of defaults
20190919.103425 D 16112 ReportStorage::DoQuery Initializing report
20190919.103425 D 16112 ReportStorage::DoQuery 2nd override of defaults
20190919.103425 D 16112 ReportStorage::DoQuery Generating the report
20190919.103425 E 16112 ReportHandler::GenerateReport Unable to generate the report
20190919.103425 I 16112 QBSDKMsgSetHandler Request 10 failed.
答案 0 :(得分:0)
我能够找到一种方法将我想要的多个报告压缩为一个大报告,但这是一种解决方法,并非总是可行的解决方案。
每个响应似乎限制为10个报告,因此这里的解决方案是每10个批处理一次。如果发现其他问题,我很乐意将其标记为正确答案。