首頁 >後端開發 >C++ >如何處理 LINQ 查詢中的空值以避免轉換失敗?

如何處理 LINQ 查詢中的空值以避免轉換失敗?

Patricia Arquette
Patricia Arquette原創
2025-01-10 20:46:41991瀏覽

How to Handle Null Values in LINQ Queries to Avoid Cast Failures?

LINQ查詢中的空值處理:解型別轉換失敗

當LINQ查詢可能傳回空值時,可能會拋出以下錯誤:「無法將值類型'Int32'轉換為null。結果類型的泛型參數或查詢必須使用可空類型。」為了解決此錯誤並允許空值,請考慮以下方法:

方法一:使用DefaultIfEmpty和Sum,並指定預設值

<code class="language-csharp">var creditsSum = (from u in context.User
                  join ch in context.CreditHistory on u.ID equals ch.UserID                                        
                  where u.ID == userID
                  select ch.Amount).DefaultIfEmpty(0).Sum();</code>

此方法使用DefaultIfEmptyCreditHistory表中沒有匹配記錄時插入一個預設值(本例中為0)。

方法二:轉換為可空型別並使用??運算子

<code class="language-csharp">var creditsSum = (from u in context.User
                  join ch in context.CreditHistory on u.ID equals ch.UserID                                        
                  where u.ID == userID
                  select (int?)ch.Amount).Sum() ?? 0;</code>

在此方法中,查詢被修改為將Amount屬性轉換為可空類型(int?)。這會通知編譯器該值可能為空。然後使用??運算子來處理空值情況,如果值為null,則賦值一個預設值(本例中為0)。

方法三:使用Coalesce函數

<code class="language-csharp">var creditsSum = (from u in context.User
                  join ch in context.CreditHistory on u.ID equals ch.UserID                                        
                  where u.ID == userID
                  select COALESCE(ch.Amount, 0)).Sum();</code>

此方法使用COALESCE函數直接在SQL查詢中將空值替換為指定的預設值(本例中為0)。

以上是如何處理 LINQ 查詢中的空值以避免轉換失敗?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn