Netsuite 一次仅返回 1000 条记录,当我尝试获取超过 1000 条记录时,它会超时。为了解决这个问题,我们可以使用分页机制。 有没有人有在 NetSuite 中进行分页的经验?提前致谢。
最佳答案
您可以使用以下代码获取无限结果(SuiteScript 1.0):
var search = nlapiLoadSearch(null, SAVED_SEARCH_ID).runSearch();
var res = [],
PAGE_SIZE = 1000, //MAX 1000, you can lower it than 1000 if search times out
currentRes;
var i = 0;
while(i % PAGE_SIZE === 0){
currentRes = (search.getResults(i, i+PAGE_SIZE) || []);
res = res.concat(currentRes );
i = i + currentRes.length;
}
就是说,search.getResults(page*PAGE_SIZE, (page*PAGE_SIZE + PAGE_SIZE))
应该给您第 n
页的结果。请注意,getResults()
具有与其关联的 API 治理点。
从2016.1开始,SuiteScript 2.0增加了用于分页搜索结果的API,代码片段如下:
/**
*@NApiVersion 2.x
*/
require(['N/search'],
function(search) {
function loadAndRunSearch() {
var mySearch = search.load({
id: 'customsearch_my_so_search'
});
var myPagedData = mySearch.runPaged();
myPagedData.pageRanges.forEach(function(pageRange) {
var myPage = myPagedData.fetch(pageRange);
myPage.data.forEach(function(result) {
var entity = result.getValue('entity');
var subsidiary = result.getValue('subsidiary');
});
});
}
loadAndRunSearch();
});
关于paging - 如何在 Netsuite 中实现 Paging?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35473909/