Delphi: как определить и опорожнить значение TDatetime
Кажется, нет способа назначить NULL (или "неприсвоенным значением " to TDateTime переменные.
единственный способ, который я себе представлял, - это использовать что-то вроде этого:
function isNull(aDate : TDateTime) : boolean;
const NullDate = 0.0;
var aNullDate : TDatetime;
ms : Int64;
begin
aNullDate := NullDate;
ms := MilliSecondsBetween(aDate,aNullDate);
result := (ms = Int64(0));
end;
есть ли кто-нибудь, кто знает лучшее решение, что не перекрывает значение даты 0?
отрицательные значения TDateTime опасно? (Как способный ресурс для предыдущей цели)
4 ответов
как Андреас уже писал,TDateTime тип на самом деле double и, следовательно, не "nullable". Я использую
const
c_UnassignedDate = -693594;
для пустого значения даты, поскольку это представляет невозможную дату 00/00/0000. Но, например, DevExpress использует
NullDate = -700000;
InvalidDate = NullDate + 1;
таким образом, кажется, нет согласованной стандартной долины, вы должны выбрать тот, который соответствует вашим потребностям.
сначала вам нужно определить, что вы подразумеваете под " пустым TDateTime значение'.
A TDateTime value-это double с датой, закодированной в целочисленной части, и временем, закодированным в дробной части. Таким образом, ближе всего к "нулевой дате" вы можете получить, вероятно,0.
следовательно, просто проверить ADate <> 0 чтобы проверить, является ли дата "null".
но будьте осторожны: если вы объявляете TDateTime локальная переменная тогда это не обязательно будет =0 прежде чем вы дадите его значение. Это может быть что угодно. Конечно, то же самое относится и к переменным типа integer, double, boolean, ...
кроме того, я считаю, что a TDateTime со значением 0 кодирует дату 1899-12-30.
в конце концов, отрицательные TDateTime значения совершенно нормальны. Например, -5000 соответствует 1886-04-22.
я не совсем понимаю смысл вашего кода. Если вы хотите использовать 0 как значение "неназначенный" (что плохо, если вы заинтересованы в даты близки к 1899-12-30), почему бы просто не
function IsUnassigned(ADate: TDateTime): boolean;
begin
result := ADate = 0;
end;
или, возможно (но не эквивалентно!),
function IsUnassigned(ADate: TDateTime): boolean;
begin
result := IsZero(Date);
end;
в своем ответе Айн дал несколько более разумных вариантов для значения "неназначенная дата".
tDateTime не определено для значений между 0 и -1, что означает, что tDateTime -0.5 является неопределенным значением и полезно для нулевой даты в качестве альтернативы NaN. DateTimeToString отобразит -0.5 то же самое, что и +0.5;
используйте PDateTime вместо TDateTime и отправьте как нулевое значение. Если нет указателя на значение, результат не имеет значения.
для проверки значения используйте назначенный ptr:
MyDatePointer := nil;
if ( Assigned(MyDatePointer)) then ...