設定 SQL Server 參數時處理可為空值
使用 SqlParameter
物件時,處理可為空值需要仔細注意。 直接將 null 值指派給整數參數(例如 SqlDbType.Int
)通常會導致錯誤「沒有從 DBNull 到 int 的隱式轉換」。這是由於類型不相容造成的。
此問題通常在使用條件運算子 (?:
) 時出現。 在處理 int
或 DBNull
.
解:使用物件轉換
一個有效的方法是將可為 null 的值強制轉換為 object
。這解決了類型歧義,因為 object
可以容納 int
和 DBNull
值。
<code class="language-csharp">SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int); planIndexParameter.Value = (object)AgeItem.AgeIndex ?? DBNull.Value;</code>
解:利用空合併運算子
另一個解利用空合併運算子 (??
)。如果左側操作數不為空,則該運算子會優雅地傳回該操作數;否則,它會傳回右側操作數。
<code class="language-csharp">SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int); planIndexParameter.Value = AgeItem.AgeIndex ?? DBNull.Value;</code>
至關重要的是,如果 AgeItem.AgeIndex
為 null,則 planIndexParameter.Value
設定為 DBNull.Value
(空值的 SQL Server 表示形式)。
透過實作這些方法之一,您可以可靠地處理 SqlParameter
物件中的空值,從而防止常見錯誤。
以上是處理可為空的 SQL Server 參數時如何避免「沒有從 DBNull 到 int 的隱式轉換」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!