确定NetSuite SuiteTalk PurchaseOrderItem类型

scd*_*scd 2 netsuite

如何确定PurchaseOrderItem是库存商品还是非库存商品?

使用NetSuite的SuiteTalk Web服务,我可以根据采购订单编号找到特定的PurchaseOrder。从purchaseOrder对象中,我可以看到代表purchaseOrderItems的项目列表。

PurchaseOrderItem[] purchaseOrderItems = purchaseOrder.itemList.item;
Run Code Online (Sandbox Code Playgroud)

我能够枚举PurchaseOrderItems。

我想提供一些其他信息,例如每个项目是库存项目还是非库存项目。另外,对于非库存物料,我需要确定其是否可实现。在NetSuite的UI中,可以通过单击项目名称并查看“可以实现/接收”(字段ID:isfulfillable)来查看此信息。

我尝试过的事情:

以下测试代码取得了一些成功。它获取item.internalID并尝试“获取”特定的RecordType。对于我感兴趣的所有记录类型,我都会重复此操作。我对这种解决方案不满意。

我希望有人可以指出正确的方向来解决这个问题。

<!-- language: c# -->
// Look up inventory item
RecordRef recordRefInventoryItem = new RecordRef();
recordRefInventoryItem.internalId = poItem.item.internalId;
recordRefInventoryItem.type = RecordType.inventoryItem;
recordRefInventoryItem.typeSpecified = true;
ReadResponse responseInventoryItem = netSuiteService.get(recordRefInventoryItem);
if (responseInventoryItem.status.isSuccess)
{
    InventoryItem inventoryItem = (InventoryItem)responseInventoryItem.record;    
}

// Look up non inventory item
RecordRef recordRefNonInventoryItem = new RecordRef();
recordRefNonInventoryItem.internalId = poItem.item.internalId;
recordRefNonInventoryItem.type = RecordType.nonInventoryPurchaseItem;
recordRefNonInventoryItem.typeSpecified = true;
ReadResponse responseNonInventoryItem = netSuiteService.get(recordRefNonInventoryItem);
if (responseNonInventoryItem.status.isSuccess)
{
    NonInventoryPurchaseItem nonInventoryPurchaseItem = (NonInventoryPurchaseItem)responseNonInventoryItem.record;
bool isFulfillable = nonInventoryPurchaseItem.isFulfillable;
}
Run Code Online (Sandbox Code Playgroud)

bknights建议后跟进。

我创建了以下代码来提取项目的内部ID,并执行ItemSearchAdvanced搜索以使它们合格。以下代码返回一个强类型的result.recordList。

List<RecordRef> itemIds = new List<RecordRef>();
foreach (PurchaseOrderItem purchaseOrderItem in purchaseOrderItems)
{
    RecordRef recordRef = new RecordRef();
    recordRef.internalId = purchaseOrderItem.item.internalId;                    
    itemIds.Add(recordRef);
}

// configure a search to locate 'anyOf' itemIds
SearchMultiSelectField searchMultiSelectField = new SearchMultiSelectField();
searchMultiSelectField.searchValue = itemIds.ToArray();
searchMultiSelectField.@operator = SearchMultiSelectFieldOperator.anyOf;
searchMultiSelectField.operatorSpecified = true;

// tell the system we want 'internalID' 'anyOf' itemIds
ItemSearchBasic itemSearchBasic = new ItemSearchBasic();
itemSearchBasic.internalId = searchMultiSelectField;

// create an item search
ItemSearch itemSearch = new ItemSearch();
itemSearch.basic = itemSearchBasic;

// create an item search advanced
ItemSearchAdvanced itemSearchAdvanced = new ItemSearchAdvanced();
itemSearchAdvanced.criteria = itemSearch;

SearchResult result = NS.search(itemSearchAdvanced);

if (result.status.isSuccess)
{
    // results.recordList has strongly type items.  Yeah!
}
Run Code Online (Sandbox Code Playgroud)

bkn*_*hts 5

我倾向于做的是收集我所有的商品内部ID,然后使用商品ID列表进行ItemSearchAdvanced。这允许您提取项目记录的所有项目类型,子类型和isFullfillable值。

可以执行此操作的另一种方法是将这些值来源到事务上的隐藏的客户字段中。