Есть ли простой способ идентифицировать все зависимые записи записи, используя SuiteScript в NetSuite?

При удалении существующих записей во время автоматизированных тестов я часто сталкиваюсь с ошибкой "Эта запись не может быть удалена, поскольку она содержит зависимые записи". Прямо сейчас я очищаю страницу зависимых записей для типов записей и идентификаторов каждой зависимой записи и удаляю их с помощью nlapiDeleteRecord, прежде чем продолжить. Должен быть лучший способ идентифицировать и удалять зависимые записи.

0 ответов

Если запись, возвращающая эту ошибку, является транзакцией, вы можете использовать несколько различных способов их идентификации.

Вы можете просмотреть строки "Ссылки" в объекте записи NetSuite следующим образом: (обратите внимание, что он действительно возвращает некоторые странные record type строки ("Bill" вместо "vendorbill" и т. д.):

var recordtype = 'purchaseorder'; // Any valid transaction record type
var recordid = 2709498; // Any valid Transaction Internal ID that has links
var recordlinks = getRecordLinks(recordtype,recordid);

/**
* Returns the an array containing the Record Type and Internal Id of each record linked to the input record
* @param {Object} rec - A NetSuite record object, or record type internal id (salesorder, purchaseorder, etc)
* @param {String} recordid - The Internal ID of the record to load (if a nlobjRecord was not provided)
* @return {Array} - Returns an array of links, or null
*/
function getRecordLinks(rec,recordid) {
    if(!(typeof rec == 'object')) rec = nlapiLoadRecord(rec,recordid);

    if(rec.getLineItemCount('links') == 0) return null;
    var links = [];
    for(var i=1,total=rec.getLineItemCount('links');i<=total;i++) {
        links.push({type:rec.getLineItemValue('links','type',i),id:rec.getLineItemValue('links','id',i)});
    }
    return links;
}

Или вы можете просто выполнить поиск, чтобы найти их. Вероятно, быстрее и вернет правильныйrecord type для каждой ссылки:

var recordid = 2709498; // Any valid Transaction Internal ID that has links
var links = nlapiSearchRecord('transaction',null,[['mainline','IS','T'],'AND',['createdfrom','IS',recordid]]);
if(links != null) {
    for(var i=0,total=links.length;i<total;i++) {
        var link_recordtype = links[i].getRecordType();
        var link_recordid = links[i].getId();
        console.log('Link type:'+link_recordtype+' ID:'+link_recordid);
        // nlapiDeleteRecord(link_recordtype,link_recordid);
    }
}
Другие вопросы по тегам