我试图根据搜索结果停止创建记录。我似乎无法通过我的SuiteScript搜索返回任何数据,即使我知道数据存在的事实。
我使用下面使用的确切过滤器创建了自定义保存搜索,并返回我要查找的结果。
为什么我可能无法检索到任何结果有什么突出的地方?
注意:sfdcAccountId变量确实有一个值,所以我在搜索有效值。
// 2.0
define(["N/error", "N/log", "N/search"], function (err, log, search) {
/**
* User Event 2.0 example showing usage of the Submit events
*
* @NApiVersion 2.x
* @NModuleScope SameAccount
* @NScriptType UserEventScript
* @appliedtorecord customer
*/
var exports = {};
function beforeSubmit(scriptContext) {
log.debug({
"title": "Before Submit",
"details": "action=" + scriptContext.type
});
if (doesCustomerExist(scriptContext)) {
throw err.create({
"name": "DUPLICATE_SFDC_ACCOUNT_ID",
"message": "Customer Already Contains SFDC Account Id",
"notifyOff": true
});
}
}
function doesCustomerExist(scriptContext) {
var sfdcAccountId = scriptContext.newRecord.getValue('custentitysfdc_account_id');
log.debug({
"title": "Before Submit",
"details": "sfdcAccountId=" + sfdcAccountId
});
if(sfdcAccountId == null || sfdcAccountId == '') return false;
var searchResult = search.create({
type: search.Type.CUSTOMER,
filters: ['custentitysfdc_account_id', search.Operator.IS, sfdcAccountId]
}).run();
return (searchResult != null && searchResult.length > 0);
}
exports.beforeSubmit = beforeSubmit;
return exports;
});
答案 0 :(得分:6)
当您在搜索时调用.run()
时,它会返回search.ResultSet
个对象。如果您在该对象上调用getRange()
,您将获得所需的结果数组。这是您的搜索的更新版本,返回search.Result[]
,您可以根据需要检查长度或迭代。
var searchResult = search.create({
type: search.Type.CUSTOMER,
filters: ['custentitysfdc_account_id', search.Operator.IS, sfdcAccountId]
}).run().getRange({start: 0, end: 1000});