Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

A consulta do Oracle sql precisa ser alterada com base no fuso horário


Encontrei a resposta para minha pergunta.

aparentemente, você precisa considerar as configurações de fuso horário ao calcular o valor da época também
  1. adicione 10 horas (10*60*60*1000 milissegundos) ao valor da época - o valor atual da época está em GMT, então para torná-lo EST (GMT+10), adicionei isso.

  2. Usado TO_TIMESTAMP_TZ em vez de 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');