У меня есть DateTime?
, который я пытаюсь вставить в поле, используя DbParameter
. Я создаю такой параметр:
DbParameter datePrm = updateStmt.CreateParameter();
datePrm.ParameterName = "@change_date";
И затем я хочу поместить значение DateTime?
в dataPrm.Value
, учитывая null
s.
Сначала я думал, что буду умным:
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 говорит:
оператор возвращает левый операнд, если он не равен NULL, или возвращает верный операнд.
Это именно то, что я хочу!
Update2: Ну, в конце концов, это было очевидно:
datePrm.Value = nullableDate ?? (object)DBNull.Value;