NetSuite 搜索返回 0 个结果

0 Results Returned from NetSuite Search

我正在尝试阻止根据搜索结果创建记录。尽管我确实知道数据存在,但我似乎无法通过我的 SuiteScript 搜索 return 任何数据。

我创建了一个自定义保存的搜索,其中使用了下面使用的确切过滤器和 return 我正在寻找的结果。

关于我可能检索不到任何结果的原因有什么突出的吗?

注意: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;
});

当您在搜索中调用 .run() 时,它 returns 一个 search.ResultSet 对象。如果您对该对象调用 getRange(),您将获得您要查找的结果数组。这是 returns search.Result[] 搜索的更新版本,您可以在其中检查长度或根据需要进行迭代。

var searchResult = search.create({
    type: search.Type.CUSTOMER,
    filters: ['custentitysfdc_account_id', search.Operator.IS, sfdcAccountId]
}).run().getRange({start: 0, end: 1000});