在 SuiteTalk 中更优雅地计算销售订单项目
Count SalesOrder Items more elegantly in SuiteTalk
我正在使用 SuiteTalk 为基于 NetSuite 的应用程序创建后端。我正在尝试计算 SalesOrders 中的项目总数。
我的问题是,在执行搜索操作以获取所有 SalesOrders 时,返回的 Record[]
对象在转换为 SalesOrder[]
时会失去精度(使用 Array.ConvertAll(...)
并手动)。就我而言,这意味着在尝试访问 itemList 字段时出现空引用异常。
我最终的解决方案如下:
for (SearchResult searchResult = _service.search(salesOrderSearch); searchResult.pageIndex <= searchResult.totalPages; searchResult = _service.searchNext()) {
if (searchResult.status.isSuccess) {
// Convert Record[] to SalesOrder[]. Note that direct conversion causes some fields to become Null
SalesOrder[] salesOrdersNull = Array.ConvertAll(searchResult.recordList, item => (SalesOrder)item);
// To avoid the null issue, send a get request for each order by its internalId
foreach (SalesOrder salesOrderNull in salesOrdersNull) {
SalesOrder salesOrder = getSalesOrder(salesOrderNull.internalId);
// Increment the count by the total number of items
count += salesOrder.itemList.item.Length;
}
} else {
string errorCodes = Helpers.generateErrorString(searchResult.status.statusDetail);
throw new SuiteTalkServiceException("count Sales Order Lines. Failed with error code(s) " + errorCodes);
}
}
然而,这会为每个销售订单调用一个获取请求,这意味着它需要时间并且非常不优雅。我缺少更优雅的解决方案吗?有没有其他人有类似的问题,还是我太笨了?
记录的 class 定义是:
public abstract partial class Record {
private string[] nullFieldListField;
/// <remarks/>
[System.Xml.Serialization.XmlArrayItemAttribute("name", IsNullable=false)]
public string[] nullFieldList {
get {
return this.nullFieldListField;
}
set {
this.nullFieldListField = value;
}
}
}
SalesOrder 的 class 定义有数千行代码,但 SchemaBrowser entry 相当清楚。
我找到了问题的答案 here。
本质上,要防止 itemList
字段变为 null
,您必须将 searchPreferences.bodyFieldsOnly
字段设置为 false
。这现在运行时间是我解决方案时间的 1/10。
我正在使用 SuiteTalk 为基于 NetSuite 的应用程序创建后端。我正在尝试计算 SalesOrders 中的项目总数。
我的问题是,在执行搜索操作以获取所有 SalesOrders 时,返回的 Record[]
对象在转换为 SalesOrder[]
时会失去精度(使用 Array.ConvertAll(...)
并手动)。就我而言,这意味着在尝试访问 itemList 字段时出现空引用异常。
我最终的解决方案如下:
for (SearchResult searchResult = _service.search(salesOrderSearch); searchResult.pageIndex <= searchResult.totalPages; searchResult = _service.searchNext()) {
if (searchResult.status.isSuccess) {
// Convert Record[] to SalesOrder[]. Note that direct conversion causes some fields to become Null
SalesOrder[] salesOrdersNull = Array.ConvertAll(searchResult.recordList, item => (SalesOrder)item);
// To avoid the null issue, send a get request for each order by its internalId
foreach (SalesOrder salesOrderNull in salesOrdersNull) {
SalesOrder salesOrder = getSalesOrder(salesOrderNull.internalId);
// Increment the count by the total number of items
count += salesOrder.itemList.item.Length;
}
} else {
string errorCodes = Helpers.generateErrorString(searchResult.status.statusDetail);
throw new SuiteTalkServiceException("count Sales Order Lines. Failed with error code(s) " + errorCodes);
}
}
然而,这会为每个销售订单调用一个获取请求,这意味着它需要时间并且非常不优雅。我缺少更优雅的解决方案吗?有没有其他人有类似的问题,还是我太笨了?
记录的 class 定义是:
public abstract partial class Record {
private string[] nullFieldListField;
/// <remarks/>
[System.Xml.Serialization.XmlArrayItemAttribute("name", IsNullable=false)]
public string[] nullFieldList {
get {
return this.nullFieldListField;
}
set {
this.nullFieldListField = value;
}
}
}
SalesOrder 的 class 定义有数千行代码,但 SchemaBrowser entry 相当清楚。
我找到了问题的答案 here。
本质上,要防止 itemList
字段变为 null
,您必须将 searchPreferences.bodyFieldsOnly
字段设置为 false
。这现在运行时间是我解决方案时间的 1/10。