Netsuite API需要很长时间才能响应

Netsuite API需要很长时间才能响应,netsuite,suitescript,Netsuite,Suitescript,我尝试根据记录类型和索引获取记录 请求:{“记录类型”:“客户”,“guu操作”:“全部获取”,“大小”:1000,“索引”:0} 它很好用。但每次Api调用都需要4-5分钟的响应时间。你知道如何减少这一时间吗 我的Restlet代码: get_all操作将调用get_Allrecords函数: /********************** Get All records of Record type *******************************/ function get

我尝试根据记录类型和索引获取记录

请求:{“记录类型”:“客户”,“guu操作”:“全部获取”,“大小”:1000,“索引”:0}

它很好用。但每次Api调用都需要4-5分钟的响应时间。你知道如何减少这一时间吗

我的Restlet代码:

get_all操作将调用get_Allrecords函数:

/********************** Get All records of Record type *******************************/

function get_Allrecords(datain) {
        var all_IDs = getAllIDs(datain);
        var len = all_IDs.length;
        var result = new Array();
        var results = new Array();
        var fields = datain.fields; 
        for (var i = 0; i < len; i++) {
                var required_result = {};
                try {
                       result[i] = **nlapiLoadRecord(all_IDs[i].getRecordType(), all_IDs[i].id);**
                       if(fields != undefined && fields.length > 0) {
                          for( var j = 0; j<fields.length; j++){
                                req = fields[j];
                                if(result[i].getFieldValue(req)  != undefined){
                                        required_result[req] = result[i].getFieldValue(req);
                                }
                                if(req == "recordtype"){
                                        required_result[req]  = all_IDs[i].getRecordType();
                                }
                          }
                     } else {
                          required_result =result[i];
                     }
                } catch (ex) {
                        if (ex.code == "INSUFFICIENT_PERMISSION") {
                        }
                } //try.... catch... ends
          results.push(required_result);
        } //for ends

      return results;
}

nlapiLoadRecord
调用
get\u Allrecords
是您的性能瓶颈。在SuiteScript中,从数据库加载整个记录是最昂贵的操作之一——特别是当记录是事务时——并且在请求中加载1000条记录

在NetSuite中加载较重的记录(即事务)可能需要几秒钟,因此1000条记录需要几分钟也就不足为奇了

您真的需要每条记录上的所有字段吗?通过只包含每个记录所需的列的单个搜索,而不是尝试加载每个完整记录,可以获得更好的性能


如果您确实需要每个记录上的所有字段,那么您可能需要查看SuiteTalk SOAP API;虽然它的性能通常比restlet慢得多,但在像这样的非常大的请求上,它的性能比restlet要好。

谢谢@erictgrubaugh
function getAllIDs(datain) {
        var MAX_SIZE = typeof(datain.size) == 'undefined' ? 200 : datain.size;
        var INDEX = 0;
        if (typeof(datain.index) !== 'undefined') {
                INDEX = datain.index * MAX_SIZE;
                MAX_SIZE += INDEX;
        }
        /*** Define search filters ***/
        var NS_filters = new Array();
        var columns = new Array();
        columns[0] = new nlobjSearchColumn('lastmodifieddate').setSort(1);
        var search = **nlapiCreateSearch(datain.recordtype, NS_filters, columns)**
        var results = search.runSearch();
        var records = results.getResults(INDEX, MAX_SIZE);
        return records;
}