我得到了一个 LINQ 查询,其中包含两个表,而某些记录不包含在子表中。我已经在使用带有 DEFAULTIFEMPTY() 的 GROUP JOIN 并且在我添加返回 Numeric Sum 的表 ITM_WH 之前它曾经工作过。我该如何处理这个错误?“ null 值不能分配给类型为 system.Decimal 的成员,这是不可为 null 的值类型”?知道在 ci.DefaultIfEmpty(0) 中使用 WH 不起作用。我需要列“Stock”来携带值 0,以防记录不存在
这是我的查询:
Dim result = From B In database.ITEM_BARCODEs
Join i In database.ITEMs On B.ITM_CODE Equals (i.ITM_CODE)
Group Join WH In database.ITM_WHs On i.ITM_CODE Equals
(WH.ITM_CODE) Into ci = Group From WH In ci.DefaultIfEmpty() Join
S In database.SUBGROUPs On i.ITM_SUBGROUP Equals (S.SubGrp_ID)
Join G In database.GROUPs On S.SubGrp_PARENTID Equals (G.GRP_ID)
Group Join P In database.ITEM_PHOTOs On i.ITM_PROFILE Equals
(P.PHOTO_ID) Into co = Group From p In co.DefaultIfEmpty()
Select BarcodeID = B.BARCODE_ID,
code = i.ITM_CODE,
barcode = B.ITM_BARCODE,
Title = i.ITM_TITLE,
Stock = WH.OPENING_QTY + WH.STOCK_IN - WH.STOCK_OUT,
Main_Price = B.ITM_PRICE, Price_lvl_2,
Subgroup = S.SubGrp_Name,
Group = G.GRP_NAME,
photo = p.ITM_PHOTO