- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
几年前我写了一个脚本(如下)(从那以后就没有编码过——所以有相当多的内容或生锈了;D),其中结果集现在超过 4000 条记录,这是编写脚本时没有预料到的。错误如下:
{"type":"error.SuiteScriptError","name":"SSS_SEARCH_FOR_EACH_LIMIT_EXCEEDED","message":"No more than 4000 search results may be returned at one time from nlobjSearchResultSet.forEachResult(callback). Please revise your search criteria or modify the callback logic so that no more than 4000 results are returned."...
解决此问题的最佳方法是使用不同的技术(例如 Map/Reduce - 我现在必须学习),或者是否有一种方法可以过滤搜索,以便仅返回一定数量的结果搜索和其余记录会在后续执行中返回/处理吗?
谢谢
//...
invoiceSearch.run().each(function(result) {
// ensure script usage okay
if (usageOkay()) {
entityID = result.getValue({
'name': 'internalid',
'join': 'customer',
'summary': search.Summary.GROUP
});
var maxAmountCustomerRecord = result.getValue({
'name': 'custentity_amount_maxorder_2years',
'join': 'customer',
'summary': search.Summary.GROUP
});
var maxAmountCalculated = result.getValue({
'name': 'formulacurrency',
'formula': 'CASE WHEN {closedate} >= ADD_MONTHS(SYSDATE, -(12 * 2)) THEN {amount} ELSE NULL END',
'summary': search.Summary.MAX
});
// in case the calculated amount is null then make it 0
maxAmountCalculated = maxAmountCalculated || 0.0;
// Only write to the customer record when a change is required
if (maxAmountCustomerRecord != maxAmountCalculated) {
updateRecord(entityID, maxAmountCalculated);
log.debug('Updating customer with entityID: ' + entityID + ', to maxAmount: ' +
maxAmountCalculated + ', from previous value of ' + maxAmountCustomerRecord);
}
return true;
}
else {
// If remaining script usage low, reschedule script
rescheduleScript(entityID);
}
});
//....
最佳答案
我个人喜欢生成完整的搜索,然后从那里解析它:
我将此函数与任何搜索对象一起使用,以 1000 block 为单位编译结果:
function getAllResults(s) {
var results = s.run();
var searchResults = [];
var searchid = 0;
do {
var resultslice = results.getRange({start:searchid,end:searchid+1000});
resultslice.forEach(function(slice) {
searchResults.push(slice);
searchid++;
}
);
} while (resultslice.length >=1000);
return searchResults;
}
然后当我想处理任何搜索时,例如:
var mySearch = search.create({
type:'invoice',
columns: [
{name: 'tranid'},
{name: 'trandate'},
{name: 'entity', sort: (params.consolidated)?search.Sort.ASC:undefined },
{name: 'parent',join:'customer', sort: (!params.consolidated)?search.Sort.ASC:undefined},
{name: 'terms'},
{name: 'currency'},
{name: 'amount'},
{name: 'amountremaining'},
{name: 'fxamount'},
{name: 'fxamountremaining'},
],
filters: [
{name: 'mainline', operator:'is',values:['T']},
{name: 'trandate', operator:'onorbefore', values: [params.startDate] }
]
});
var myResults = getAllResults(mySearch );
myResults.forEach(function(result) {
//... do stuff with each result
});
我在超过 20,000 条记录的数据集上使用此方法并取得了良好的结果。
关于javascript - Suitescript 2.0 ResultSet.Each 回调函数超过 4000,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54203574/
我使用这个 cmd 应用程序 https://github.com/tokland/youtube-upload 上传 50 个视频后,我收到此错误: [RequestError] Server re
尝试将 docker 容器提交到镜像时出现错误: [root@dockerregistry /]# docker commit da4180ab1536 dockerregistry:5000/myi
我只是想知道这样做会更好吗: if((fd = open(filename, O_RDWR)) == -1) { fprintf(stderr, "open [ %s ]\n", strerror(e
我在我的开发机器(单个笔记本)中使用 Elasticsearch 1.4.4。一切都设置为默认值,因为我从未更改过任何设置。 当我启动它时,我通常会收到以下消息: [2015-10-27 09:38:
我收到错误 Lock wait timeout exceeded;尝试重新启动事务。这是什么原因,如何解决?仅供引用:MySQL 配置文件中的 innodb_lock_wait_timeout = 1
我对 Slack 中的 block 功能有疑问。有人设法构建 3 列而不是 2 列吗? 我凭直觉尝试了以下代码,但它不起作用: { "blocks": [ {
div 中的内容超过由 css 决定的固定大小。 #fixeddiv { position: fixed; margin: auto; max-height: 300px
我想将 EditText 字段限制为 150 个字符,我可以很容易地做到这一点。但是,当用户试图超过该限制时,我还需要通过键入(即第 151 个字符)或粘贴超过 150 个字符来提醒用户。 解决这个问
我目前正在使用此代码并排记录两个窗口: ffmpeg -f gdigrab -framerate 30 -i title="" -f gdigrab -framerate 30 -i title=""
我在几个包含长字符串的单元格上使用嵌套的 SUBSTITUE 函数,并定期更新 SUBSTITUE fx,这导致我将其复制并粘贴到所有需要它的单元格中。问题是,我的 SUBSTITUTE 列表会随着时
我创建了一个标题 div,如下所示:
Here is the demo link 您怎么看,页面中只有 8 个广告可见,但我有 14 个广告。我已阅读有关广告限制的信息 here但不明白是不是我的情况?有人可以给我确切的答案,为什么我看不
我的非常简单的算法 - C 中的快速排序有问题。它非常有效(随机化大约 0.1 秒并检查列表是否已排序)但是当我想要对超过 500k 的元素进行排序时它会崩溃。不幸的是,我需要对它们进行更多排序,因为
我成功解决了一个关于 Hackerrank 的问题,它通过了所有测试用例,但我得到了一个错误,超过了时间限制。我猜如果我优化我的代码它会工作,但我想不出任何方法来使我的代码更有效率。 问题是: 对大小
你会如何用 包围下面的文字3 个反引号 ```使用 tpope 的 Vim Surround . 我所能做的就是 1 个反引号 使用 S`在视觉模式下: 最佳答案 这不是你问的,但这可以在没有环绕的情
我目前有一个模拟账户。我正在尝试为我的雇主使用 SwifType 制作 POC。我们有一个非常大的数据库,每 1 小时索引一次,并创建一个 JSON 文件。我认为与 Elastic 的集成将非常容易,
我为一个大约有 100 到 120 名成员的小型组织维护网站。 每个月,我们都会发送一封电子邮件,通知我们的成员我们将在即将举行的 session 中讨论的主题。 我正在尝试使用我们的网站为我们提供一
这个问题已经有答案了: How to automatically input an array formula as string with more than 255 characters in l
我有一个在 JBoss 6.1 中运行的 JSF 应用程序,它使用内部Tomcat Servlet 容器。 我已经通过apache commons文件上传实现了上传。我想防止上传过大的文件并设置了属性
当我尝试在 PyMySQL 上执行查询时,出现以下错误: pymysql.err.InternalError: (1205, 'Lock wait timeout exceeded; try rest
我是一名优秀的程序员,十分优秀!