Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Display local time from utc time stored in sql database on asp.net app

I've got times saved in a sql database in utc format. I'm displaying those times on a gridview, however they are still UTC format. I'd like to convert them to the client's browsers local time. The problem is that although I can get the timezone offset that is only for the current date/time. That offset could change if some of those dates in the future end up occuring during daylight savings time. I'm relatively new to web programming but it seems like what I need to do is run some Javascript as each entry binds to the gridview that somehow takes the C# datetimeoffset object and converts it to a local time. Or maybe that's not possible?

like image 273
JonF Avatar asked Feb 15 '10 02:02

JonF


People also ask

How do I convert UTC time to local time in SQL?

SELECT CONVERT(datetime, SWITCHOFFSET(CONVERT(DATETIMEOFFSET, GETUTCDATE()), DATENAME(TZOFFSET, SYSDATETIMEOFFSET()))) AS LOCAL_IST; Here, the GETUTCDATE() function can be used to get the current date and time UTC. Using this query the UTC gets converted to local IST.

How do I convert UTC to Central time in SQL?

If you only need to convert from UTC to CST. You can simply use DATEADD(hour, -6, Timestamp) in your query.

Is timestamp in UTC in SQL?

The TIMESTAMP and TIMESTAMPTZ data types store a date and time pair in UTC.


2 Answers

This can be done on the server side if you have a TimeZoneInfo object. You can use the static ConvertTimeFromUtc() method.

In C#:

DateTime localTime = TimeZoneInfo.ConvertTimeFromUtc(myDbDateTime, myTimeZoneInfo);

If you do not have the timezone on the server side things get tricky since javascript does not provide the client's timezone (unless they are in the US, and even then only on some browsers). In this case, it may be best to force the user to select their current timezone and store it against their account. If this is being displayed to anonymous users, you should probably display in UTC by default and provide an option to refresh it for a selected timezone.

Update

There are several issues which appear when trying to automatically determine a user's timezone.

  1. Timezone is not provided to the server by the user agent.
  2. Javascript does not provide access to the timezone (except in some browsers, sometimes).

The javascript function getTimezoneOffset() may initially sound like a good idea, but since there are multiple timezones with the same offset, this is not a unique value. The difference between many of these non-unique zones is their implementation of daylight saving time.

Example: Indiana does not regard DST. Therefore, for half the year their offset matches eastern time, while the other half their offset is equal to central time.

If, however, your user base is located primarily in the US and uses IE, Chrome, Safari, or Firefox, than you can use the toString() method on a Date object to obtain the timezone. These browsers append the timezone to the date string in different ways. Outside the US, the timezone is not included in all browsers (though some may still show it).

Open http://jsbin.com/onulo3 to observe:
IE8: Sun Feb 14 22:12:22 EST 2010
Chrome: Sun Feb 14 2010 22:12:22 GMT-0500 (Eastern Standard Time)
Safari: Sun Feb 14 2010 22:12:22 GMT-0500 (Eastern Standard Time)
Firefox: Sun Feb 14 2010 22:12:22 GMT-0500 (Eastern Standard Time)

With some parsing, you can now determine the timezone for all your American users. For everyone else you can display the time in UTC (with a notice to that effect).

like image 104
Joel Avatar answered Sep 18 '22 12:09

Joel


I found the following on "Indiana Daylight Savings Time": http://www.timetemperature.com/tzus/indiana_time_zone.shtml

As of now, 1/18/2010, a Microsoft system library call TimeZoneInfo.ConvertTimeFromUtc seems to reflect this behavior, am checking ..

like image 41
WFB Avatar answered Sep 21 '22 12:09

WFB