sql >> Database teknologi >  >> RDS >> PostgreSQL

Parsing dato med forskellige tidszoner

Hvis jeg forstår det rigtigt, skal du indstille tidszonen på det samme data-/kalenderobjekt, som du udskriver. Sådan:

private Locale locale = Locale.US;
private static final String[] tzStrings = {
    "America/New_York",
    "America/Chicago",
    "America/Denver",
    "America/Los_Angeles",
};

  Date now = new Date();
  for ( TimeZone z : zones) {
        DateFormat df = new SimpleDateFormat("K:mm a,z", locale);
        df.setTimeZone(z);
        String result = df.format(now);
        System.out.println(result); 
  }

hvis jeg indstiller tidszonen til SimpleDateFormat, fungerer det fint.

her er prøvekoden...

String date="05/19/2008 04:30 AM (EST)";
SimpleDateFormat sdf = new SimpleDateFormat("MM/dd/yyyy hh:mm aaa (z)");
TimeZone.setDefault(TimeZone.getTimeZone("PST"));
long millis = sdf.parse(date).getTime();
sdf.setTimeZone(TimeZone.getDefault());
System.out.println(sdf.format(new Date(millis)));


  1. Pivot uden aggregatfunktion i MSSQL 2008 R2

  2. Vælg rækken med max i en kolonne - MySQL

  3. Sådan bruger du jQuery SlickGrid med PHP / MySQL (indlæs serverdata og gem ændringer)

  4. postgres til MS Access