I’m trying to reuse the same code I’ve always used but now it is encountering an error.
I’m looping through various user tables, and in there I do this:
DateTime dcdt = (DateTime)u.DateCreated;
DateTime lldt = (DateTime)u.LastLogon;
userRow["DateCreated"] = dcdt.ToShortDateString();
inside the loop. I get the error:
System.InvalidOperationException: Nullable object must have a value.
The error highlights “lldt” line, instead of “dcdt” which comes first. That is strange in and of itself. Both these fields in the database “allow nulls” is checked. And they both could be null or neither might be null.
The two values are both listed as DateTime? types through intellisense.
I don’t understand why ASP.NET refuses to allow me to output blank for null dates. If it is empty/null, then logic would suggest that ASP.NET should just print nothing.
How else am I suppose to output null dates? I tried adding if statements to prevent trying to cast null DateTimes, but it doesn’t help, it makes no sense.
As you’ve said, the data type of
u.LastLogonisDateTime?. This means that it may or may not have a value. By casting toDateTime, you are requiring it to have a value. In this case, it does not.Depending on what you’re trying to do with it, you may want to check the
HasValueproperty:If your database
LastLogoncolumn is of DateTime type, then you should be able to do: