首页 > 解决方案 > 在 SuiteTalk 中更优雅地计算 SalesOrder 项目

问题描述

我正在使用 SuiteTalk 为基于 NetSuite 的应用程序创建后端。我正在尝试计算 SalesOrders 中的项目总数。

我的问题是,在执行搜索操作以获取所有 SalesOrders 时,返回的对象在转换为 a (使用和手动)Record[]时会失去精度。就我而言,这意味着在尝试访问 itemList 字段时会出现空引用异常。SalesOrder[]Array.ConvertAll(...)

我的最终解决方案如下:

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);
                }
            }

然而,这对每个销售订单都调用了一个获取请求,这意味着它需要一个时间并且非常不雅。我缺少更优雅的解决方案吗?有没有其他人有类似的问题,还是我很密集?

Record 的类定义是:

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 的类定义有几千行代码,但SchemaBrowser 条目相当清晰。

标签: c#netsuitesuitetalk

解决方案


我在这里找到了我的问题的答案。

本质上,为了防止itemList字段变为null,您必须将searchPreferences.bodyFieldsOnly字段设置为false。现在运行时间是我解决方案时间的 1/10。


推荐阅读