Oracle
 sql >> Database >  >> RDS >> Oracle

La query SQL di Oracle deve cambiare in base al fuso orario

Ho trovato la risposta alla mia domanda.

a quanto pare, devi considerare le impostazioni del fuso orario anche quando calcoli il valore dell'epoca

  1. aggiungi 10 ore (10*60*60*1000 millisecondi) al valore di epoch - il valore corrente di epoch è in GMT, quindi per renderlo EST (GMT+10), ho aggiunto questo.
  2. Usato TO_TIMESTAMP_TZ invece di to_date

    SELECT tableA.columnA,tableB.columnB 
    FROM tableA INNER JOIN tableB ON  tableA.aId = tableB.aId 
    WHERE (TO_TIMESTAMP_TZ('1970-01-01 00:00:00 +10:00','yyyy-MM-dd hh24:mi:ss TZH:TZM') +    ((tableB.epochValue+(10*60*60*1000))/60/60/24/1000)) >  to_date('##FROM_DATE## +10:00', 'yyyy-MM-dd hh24:mi:ss TZH:TZM') 
    AND (TO_TIMESTAMP_TZ('1970-01-01 00:00:00 +10:00','yyyy-MM-dd hh24:mi:ss TZH:TZM') + ((tableB.epochValue+(10*60*60*1000))/60/60/24/1000)) <= to_date('##TO_DATE## +10:00', 'yyyy-MM-dd hh24:mi:ss TZH:TZM');