如何使用oData和服务层从StockTransferRequest中删除StockTransferLine

2020-08-25 15:59发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)我们正在编写一个应用程序,该应用...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


我们正在编写一个应用程序,该应用程序将允许我们使用oData和HANA服务层对库存调拨请求执行CRUD操作。 到目前为止,我们已经能够添加和修改单个库存转移请求和行。 但是,删除不会对StockTransferLines产生任何影响,即,如果我"删除"了StockTransferRequest中StockTransferLines集合中的特定行,则会忽略此行,并在更新StockTransferRequest时保留该行。

我在下面添加了一个代码段,该段注释了有效/无效的位:

HanaConnectionhanaConnection = newHanaConnection(connString.ConnectionString);

hanaConnection.Open();

SAPServiceLayer.SAPB1.StockTransferstockTransferRequestUpdate = newSAPServiceLayer.SAPB1.StockTransfer();

stockTransferRequestUpdate = currentOdataService.GetStockTransferRequest(1044);

if(null!= stockTransferRequestUpdate)

{

//添加行-没有问题的工作

StockTransferLinestl_11 = newStockTransferLine();

stl_11.ItemCode =" 10";

stl_11.Quantity = 1;

stl_11.UnitPrice = 2;

stl_11.FromWarehouseCode =" MAIN";

stl_11.WarehouseCode =" 002";

stockTransferRequestUpdate.StockTransferLines.Add(stl_11);

StockTransferLine stl = stockTransferRequestUpdate.StockTransferLines.Where(tl => tl.LineNum == 1).Single();

//修改现有线路

stl.Quantity = 10;

stl.ItemCode =" 100";

//删除行-无效,并且不会引发我看到的任何错误

stockTransferRequestUpdate.StockTransferLines.Remove(stl);

//或

stockTransferRequestUpdate.StockTransferLines.RemoveAt(1);

//使用上面的添加/修改/删除选项更新StockTransferRequest

boolupdateSTR = currentOdataService.UpdateStockTransferRequest(stockTransferRequestUpdate);

}

我以B1ADMIN用户身份连接,并拥有对数据库CRUD的完整权限。

鉴于添加一行; 并修改现有的线路可以正常工作。 我在想,要么我错过了令人眼花obvious乱的事情,要么是Remove方法要求在用户以外的其他地方显式允许其他权限,或者Remove方法依赖于其他操作/修正。

有人可以帮我指出正确的方向吗?

谢谢!

Rob

6条回答
spaceman01
2020-08-25 16:44

嗨 拉尔夫,

是的,您是正确的,我正在通过WCF使用oData,目前我比REST更满意。 因此,正如您所说,WCF实现可能存在错误。 看起来我将不得不在REST中进行自我训练。 我将查看您的肮脏样本,以查看是否可以使用此样本来工作。

谢谢!

Rob

一周热门 更多>