我应该将它存储在单个时间戳/日期时间字段还是单独的日期和时间字段中?我更喜欢将它存储为单个时间戳字段,但我需要知道用户何时没有输入时间部分。

如何在数据库中最好地存储它?我正在使用postgresql。

有帮助吗?

解决方案

肯定有理由说这是一个坏主意。您的选择有限也是有原因的。这是一个坏主意,因为它是一个单一的数据项,更实际的原因是,如果你有两个字段,你就无法存储时区。

如上所述,空值是使用两个字段的明显好处。

您可能还需要考虑使用单个日期时间字段并存储标志以指示用户是否输入了时间。这可能是一个布尔标志。但是,您仍然需要考虑如何使用此数据 - 仅在日期时间字段中输入日期将导致时间组件设置为午夜。这将对排序和选择产生影响。此外,如果您要存储时区,则在使用数据时必须非常小心。

为了满足您了解是否输入时间的要求,您需要有两个字段。你不需要第二个字段。

其他提示

显而易见的答案是使用两个单独的字段;那么你可以使用NULL值。

如果您选择使用一个字段,则需要选择表示“未输入实时”的魔术时间部分,这有可能与实时重合(但不太可能)。

另外,如果您打算经常单独使用日期和时间部分,那么使用单独的字段也可能很方便;否则你经常需要使用选择函数来提取字段的相关部分。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top