使用aftersubmit函数创建用户事件脚本时出现RCRD_DSNT_EXIST

时间:2019-04-23 19:41:57

标签: netsuite suitescript suitescript2.0

我正在尝试编写一个用户事件脚本,该脚本加载当前记录并在提交记录后通过搜索填充订单项值。但是,即使记录存在,它也会给出错误RCRD_DSNT_EXIST。

function afterSubmit_SO(type){
    try
    {        
        //var record_type = nlapiGetRecordType();
        var recordID = nlapiGetRecordId();    
        var context = nlapiGetContext();
        var recordOBJ = nlapiLoadRecord('salesorder',recordID);
        var source = context.getExecutionContext();
       if(source == 'userinterface') 
        {
            var line_count = recordOBJ.getLineItemCount('item');
            nlapiLogExecution('DEBUG', 'line count ', line_count);
            for(var i = 1; i <= line_count; i++)
            {
                var itemID = recordOBJ.getLineItemValue('item','item',i); 
                nlapiLogExecution('DEBUG', 'item ID', itemID);             
                var filter = new Array();
                filter[0] = new nlobjSearchFilter('internalid', null, 'is', itemID);                    
                var columns = new Array();
                columns[0] = new nlobjSearchColumn('custitem_web_market_availability');               
                var a_search_results = nlapiSearchRecord('item',null,filter,columns);               
                if(a_search_results)
                {   
                    for(var x = 0; x < a_search_results.length; x++) 
                    {                    
                        var item_web_availability = a_search_results[x].getText('custitem_web_market_availability');                                                                                            
                        nlapiLogExecution('DEBUG', 'value', item_web_availability);
                    }
                }       recordOBJ.setLineItemValue('item','custcol_web_item_availability',i,item_web_availability);                
            }    
            var submitID = nlapiSubmitRecord(recordOBJ, true, true);
        } 
    }  
    catch(exception)
    {
    nlapiLogExecution('DEBUG','Exception Caught ','' + exception);
    }

    return true;     
}```

1 个答案:

答案 0 :(得分:1)

可能是您的脚本正在执行删除操作。您提供的代码中没有对此进行任何检查。如果这是一个删除操作,则提交后用户事件脚本将无法加载已删除的记录,这就是您收到错误的原因。

afterSubmit函数的type参数应包含操作类型。您可以在脚本顶部输入if (type == 'delete') { return true;}之类的内容。