0结果从NetSuite Search

时间:2017-03-31 13:43:36

标签: javascript netsuite suitescript

我试图根据搜索结果停止创建记录。我似乎无法通过我的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;
});

1 个答案:

答案 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});