一次记录快速查询报告请求的数量是否受到限制?

时间:2019-09-17 20:17:21

标签: c# quickbooks qbfc

在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.

1 个答案:

答案 0 :(得分:0)

我能够找到一种方法将我想要的多个报告压缩为一个大报告,但这是一种解决方法,并非总是可行的解决方案。

每个响应似乎限制为10个报告,因此这里的解决方案是每10个批处理一次。如果发现其他问题,我很乐意将其标记为正确答案。