Following on from the discovery of this issue and the workaround of deleting the blank item from InventTable, the blank item kept reappearing in the database and it was decided to modify the Master Planning code to discard items with a blank ItemId.
This was done by making a simple change to the createListsFromQueryRun method of the ReqTransCache_Periodic class which builds the item lists used by master planning.
while (runQuery.next())
{
inventTable = runQuery.get(tablenum(InventTable));
// Discard any items with a blank ItemId
if (inventTable.ItemId == "")
{
continue;
}
if (!levelItemMap.exists(inventTable.bomLevel))
{
itemSet = new Set(Types::String);
levelItemMap.insert(inventTable.bomLevel, itemSet);
}
else
itemSet = levelItemMap.lookup(inventTable.bomLevel);
itemSet.add(inventTable.ItemId);
}
Thanks for the post, it saves lot of time.
ReplyDelete