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