Dal Joda Time FAQ:
Are bisestili secondi supportati?
Joda-Time non supporta i secondi bisestili. I secondi di salto possono essere supportati scrivendo una nuova cronologia specializzata, o apportando alcuni miglioramenti alla classe ZonedChronology
esistente. In entrambi i casi, le versioni future di Joda-Time non abiliteranno automaticamente i secondi bisestili. La maggior parte delle applicazioni non ne ha bisogno e potrebbe avere costi di prestazioni aggiuntivi.
Da IANA/Olson TZDB file on leap seconds:
Anche se la definizione include anche la possibilità di far cadere secondi ("negativi" bisestili secondi), questo non è mai stato fatto ed è improbabile che sia necessaria nel prossimo futuro.
La tua prima domanda:
Come per assicurarsi che il TS è sempre in aumento e non all'indietro?
Uno negativo secondo intercalare lascerebbe voi allo stesso timestamp (un valore per due secondi trascorsi), quindi non si può davvero andare indietro senza due secondo salto negativo. Dal momento che non sembra probabile che ci saranno mai secondi bisestili negativi, direi che questo è un problema che non incontrerai mai.
Aggiornamento: L'unico modo in cui posso prevedere il timestamp all'indietro è se si utilizza la precisione in millisecondi e si verifica il comportamento n. 3 di seguito.
tua seconda domanda:
come selezionare esattamente l'intervallo 100s da db che tengono conto nel secondo intercalare?
Poiché i tempi di registrazione sono in UTC, i valori sono già comprensivi di secondi bisestili. So che può sembrare contro-intuitivo, dal momento che come hai descritto ci sono esattamente 86400 secondi (86400000 ms) in un giorno da questa scala. Ma sono davvero lì dentro. Se non lo fossero, allora verremmo sincronizzati con TAI, non con UTC. Quindi, come può essere? Beh, ci sono un paio di cose diverse che possono accadere quando si verifica un secondo intercalare:
Se secondo salto sono supportati sia dal sistema operativo e il codice dell'applicazione, allora potrebbe mostrare davvero uno spettacolo secondi come :60
o :61
. Ma non ci sono quasi reali implementazioni di questo perché i linguaggi di programmazione di solito consentono solo i secondi che vanno a :59
.
Il sistema operativo potrebbe "bloccarsi" per un secondo, fornendo lo stesso valore per un intero secondo.
Il sistema operativo potrebbe passare a :59.999
e quindi tornare a :59.000
per ripetere il periodo coperto dal secondo intercalare. (grazie @Teo)
Il sistema operativo potrebbe "drift" o "smear" per un po ', aggiungendo lentamente alcuni millisecondi alla volta all'orologio di sistema, fino a quando non ha raggiunto il secondo extra.
Il sistema operativo potrebbe saltare direttamente su di esso e non fare nulla. L'orologio non sarà sincronizzato fino alla prossima sincronizzazione con NTP. E se è successo sincronizzare proprio al momento del secondo intercalare, probabilmente sarà sufficiente impostare l'ora su :59
o :00
e di nuovo essere fuori sincrono per un po '.
Consideriamo un esempio reale. Il valore 1341100800000
rappresenta il 1 ° luglio 2012 esattamente alla mezzanotte UTC. (È possibile verificarlo su this web site o nel proprio codice Java o Joda. Per verificare.) Se dividiamo per 86400000, otterremo esattamente i 15522 giorni trascorsi dal 1/1/1970 UTC.
Questo valore è compreso dei 35 secondi bisestile, compreso quello che è accaduto solo un secondo prima alla fine della giornata del 30 giugno 2012. È come se il secondo intercalare non fosse mai accaduto.
Quindi la maggior parte delle volte non è necessario preoccuparsi dei secondi bisestili. Fai finta che non esistano. Lascia che il tuo sistema operativo li gestisca nel modo che preferisce.
Se si richiedono misurazioni del tempo ultra precise, forse in un contesto scientifico, non si dovrebbe comunque utilizzare l'orologio di sistema del computer. Oltre al fatto che il secondo intercalare può essere trattenuto, allungato o ignorato, non è progettato per essere preciso di un timer. Invece, probabilmente dovresti lavorare con hardware di cronometraggio molto specializzato, come quelli offerti da this vendor.
Aggiornamento: Nei casi in cui è necessario occuparsi di secondi bisestili è se si registrano eventi rapidamente (molti eventi al secondo) e se il sistema operativo ha il comportamento descritto in # 3 sopra. In questo caso, la mia raccomandazione sarebbe quella di non ordinare per data e ora, ma invece di prendere in considerazione un numero di sequenza a parte monotonicamente crescente della tua, e ordinare invece quello.
Ad esempio, è possibile che nel database sia già presente un numero intero a incremento automatico. Si potrebbe ancora filtro per data e ora nella clausola where per ottenere dati per una data particolare, ma si ordinerà quindi dall'ID in modo che gli eventi siano in sequenza anche se i timestamp non lo erano.
Per altri suggerimenti, vedere Teo's answer.
+1 ma l'implementazione di questo sullo strato db può sembrare più semplice di quanto non sia (pensando al famoso ORA-04091: la tabella XXXX sta mutando, trigger/funzione potrebbe non vederlo) –
Vieni a pensarci forse è davvero è più semplice di quanto pensassi. Il controllo per il secondo intercalare può essere anche codificato nel codice di inserimento SQL. L'unico problema (che non dovrebbe essere affatto un problema) sarebbe quello di leggere (e incrementare nel database stesso) un conteggio "smear" (il numero di millisecondi che aggiungi artificialmente). – Sandman
@ HAL9000: l'errore "trigger si sta mutando" di solito si verifica quando le persone non capiscono che Oracle ha trigger a livello di riga che non richiedono alcun DML sulla tabella attivata.E il codice sopra potrebbe cambiare il tempo per una singola riga senza problemi (anche se non userei un trigger per questo - una procedura che gestisca tutto sarebbe una scelta migliore) –