![]() ![]() ![]() Of course you may also notice that it is possible to treat such cases also with time zone, if you keep track of the rule changes in the regions/timezones of your interest, and update the affected records. The most common rule that changes is about the adoption or not of day light saving time (DST).įor example, imagine that you are at, let's say, (not yet in DST) schedule some event to happen at 10:00 (which would be already in DST), and at your region was designated to adopt DST but, some time after that, the government changed the rule and say your region will no longer use DST, and suddenly your scheduled time becomes 11:00 (instead of 10:00), that if you use timestamp WITH time zone, and keep your TZ configurations up-to-date. That could be good for timestamp WITH time zone if, and only if, the rules defined by region's laws about time zone didn't ever change. That is when you want to store events in the future and that some kind of alert must be triggered when we got to that time. Now, with those two down, I can came with only one good reason to use timestamp WITHOUT time zone. But it is also considered an anti-pattern, simple because the correct solution for (1) is to configure the TimeZone setting to the given one timezone for the system and (2) is already solved, as PostgreSQL already stores everything on the same timezone (UTC). It is considered valid for some to use timestamp WITHOUT time zone in situations where (1) everything is in the same timezone or (2) the application layer handles the time zone and just store everything in a certain time zone (usually UTC). If no time zone is stated in the input string, then it is assumed to be in the time zone indicated by the system's TimeZone parameter, and is converted to UTC using the offset for the timezone zone. An input value that has an explicit time zone specified is converted to UTC using the appropriate offset for that time zone. What it does is to store every data in UTC time zone, as stated in the docs:įor timestamp with time zone, the internally stored value is always in UTC (Universal Coordinated Time, traditionally known as Greenwich Mean Time, GMT). This is stated in a lot of places, but I think it worth mentioning always when we compare the timestamp with time zone with timestamp without time zone types: the timestamp WITH time zone does not store the time zone information along with the timestamp.
0 Comments
Leave a Reply. |
AuthorWrite something about yourself. No need to be fancy, just an overview. ArchivesCategories |