确定 NetSuite SuiteTalk PurchaseOrderItem 类型
Determine NetSuite SuiteTalk PurchaseOrderItem Type
如何确定 PurchaseOrderItem 是库存项目还是非库存项目?
使用 NetSuite 的 SuiteTalk Web 服务,我根据 PO 编号找到了特定的 PurchaseOrder。从 purchaseOrder 对象中,我可以看到表示 purchaseOrderItems 的项目列表。
PurchaseOrderItem[] purchaseOrderItems = purchaseOrder.itemList.item;
我能够枚举 PurchaseOrderItems。
我想包括一些附加信息,例如每件商品是库存商品还是非库存商品。此外,对于非库存项目,我需要确定它是否可履行。在 NetSuite 的 UI 中可以通过单击项目名称并查看 "Can be fulfilled/received"(字段 ID:isfulfillable)来查看此信息。
我尝试过的事情:
我通过以下测试代码取得了一些成功。它获取 item.internalID 并尝试 "get" 特定的 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;
}
根据bknights的建议跟进。
我创建了以下代码来提取项目的内部 ID,并执行 ItemSearchAdvanced 搜索以限定它们。下面的代码 returns 是一个强类型 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!
}
我倾向于做的是收集我所有的项目内部 ID,然后使用项目 ID 列表执行 ItemSearchAdvanced。这允许您提取项目记录的所有项目类型、子类型和 isFullfillable 值。
您可以执行此操作的另一种方法是将这些值提供给交易中隐藏的 custcol 字段。
如何确定 PurchaseOrderItem 是库存项目还是非库存项目?
使用 NetSuite 的 SuiteTalk Web 服务,我根据 PO 编号找到了特定的 PurchaseOrder。从 purchaseOrder 对象中,我可以看到表示 purchaseOrderItems 的项目列表。
PurchaseOrderItem[] purchaseOrderItems = purchaseOrder.itemList.item;
我能够枚举 PurchaseOrderItems。
我想包括一些附加信息,例如每件商品是库存商品还是非库存商品。此外,对于非库存项目,我需要确定它是否可履行。在 NetSuite 的 UI 中可以通过单击项目名称并查看 "Can be fulfilled/received"(字段 ID:isfulfillable)来查看此信息。
我尝试过的事情:
我通过以下测试代码取得了一些成功。它获取 item.internalID 并尝试 "get" 特定的 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;
}
根据bknights的建议跟进。
我创建了以下代码来提取项目的内部 ID,并执行 ItemSearchAdvanced 搜索以限定它们。下面的代码 returns 是一个强类型 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!
}
我倾向于做的是收集我所有的项目内部 ID,然后使用项目 ID 列表执行 ItemSearchAdvanced。这允许您提取项目记录的所有项目类型、子类型和 isFullfillable 值。
您可以执行此操作的另一种方法是将这些值提供给交易中隐藏的 custcol 字段。