首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >确定NetSuite SuiteTalk PurchaseOrderItem类型

确定NetSuite SuiteTalk PurchaseOrderItem类型
EN

Stack Overflow用户
提问于 2015-09-23 17:05:18
回答 1查看 696关注 0票数 3

如何确定PurchaseOrderItem是库存项还是非库存项?

使用NetSuite的SuiteTalk web服务,我根据PO号定位特定的PurchaseOrder。在purchaseOrder对象中,我可以看到表示purchaseOrderItems的项目列表。

代码语言:javascript
复制
PurchaseOrderItem[] purchaseOrderItems = purchaseOrder.itemList.item;

我能够枚举PurchaseOrderItems。

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

我尝试过的事情:

下面的测试代码取得了一些成功。它抓住item.internalID并尝试“获取”特定的RecordType。对于我感兴趣的所有记录类型,我都要重复这一点。我对这个解决办法感到不舒服。

我希望有人能为我指出解决这个问题的正确方向。

代码语言:javascript
复制
<!-- 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;
}

根据骑士的建议进行跟踪。

我创建了下面的代码来提取条目的内部I,并执行ItemSearchAdvanced搜索来限定它们。下面的代码返回强类型的result.recordList。

代码语言:javascript
复制
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!
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-23 17:46:59

我倾向于收集所有的项目内部is,然后使用项目is列表执行一个ItemSearchAdvanced。这允许您提取项目记录的所有项类型、子类型和isFullfillable值。

您可以这样做的另一种方法是将这些值源到事务中隐藏的custcol字段中。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32745452

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档