簡體   English   中英

如何處理從LINQ to SQL中的存儲過程返回的NULLable Int列

[英]How can I handle a NULLable Int column returned from a stored procedure in LINQ to SQL

我有一個存儲過程返回兩個int值。 第一個不能為null,但第二個實際上可以返回null值。 當我嘗試使用LINQ to SQL執行我的存儲過程時,它失敗並帶有以下語句:

無法將null值分配給類型為System.Int32的成員,該類型是非可空值類型。

我試圖在我的DBML中更改我的設計器文件並添加: CanBeNull= true到存儲過程結果的列映射。

我似乎可以找出處理這個問題的正確方法,不確定我是否可以更改我的LINQ / C#代碼來解釋null(這將是更好的選擇),或者我是否必須以某種方式更新我的存儲過程。

您需要將變量聲明為可為空。 在設計器中,單擊模型中需要可為空的屬性 ,然后在“ 屬性”窗口中,將“Nullable”屬性設置為True 這將告訴生成器將您的屬性創建為Nullable<int> or int?

嘗試將int變量聲明為可空。

int? myInt;

這樣你可以檢查它們是否為null。

我也得到了這個錯誤,原因是我已經更改了一個字段以允許在表中使用null但我沒有在.dbml文件中刪除該表。 通過刪除並再次刪除.dbml文件中的表來解決此問題。

希望這對其他一些用戶有所幫助。

謝謝。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM