C # ADO.NET: null и DbNull - есть ли более эффективный синтаксис?

у меня естьDateTime? что я пытаюсь вставить в поле с помощьюDbParameter, Я создаю параметр следующим образом:

DbParameter datePrm = updateStmt.CreateParameter();
datePrm.ParameterName = "@change_date";

И тогда я хочу поставить значениеDateTime? вdataPrm.Value при учетеnulls.

Сначала я думал, что буду умным

datePrm.Value = nullableDate ?? DBNull.Value;

но это не с ошибкой

Оператор '??' не может быть применен к операндам типа 'System.DateTime?' и 'System.DBNull'

Поэтому я думаю, что это работает, только если второй аргумент является ненулевой версией первого аргумента. Итак, я пошел за:

datePrm.Value = nullableDate.HasValue ? nullableDate.Value : DBNull.Value;

но это тоже не работает:

Тип условного выражения не может быть определен, поскольку не существует неявного преобразования между «System.DateTime» и «System.DBNull»

Но я не хочу конвертировать между этими типами!

Пока единственное, что я могу заставить работать:

if (nullableDate.HasValue)
  datePrm.Value = nullableDate.Value;
else
  datePrm.Value = DBNull.Value;

Это действительно единственный способ, которым я могу написать это? Есть ли способ заставить однострочник использовать троичный оператор для работы?

Обновить: Я действительно не понимаю, почему ?? версия не работает. MSDN говорит:

?? Оператор возвращает левый операнд, если он не равен нулю, или возвращает правый операнд.

Это именно то, что я хочу!

Update2: Ну, в конце концов, это было очевидно:

datePrm.Value = nullableDate ?? (object)DBNull.Value;

Ответы на вопрос(6)

Ваш ответ на вопрос