Q Idioma - Datos temporales

los q el lenguaje tiene muchas formas diferentes de representar y manipular datos temporales, como horas y fechas.

Fecha

Una fecha en kdb + se almacena internamente como el número entero de días desde que nuestra fecha de referencia es 01Jan2000. Una fecha posterior a esta fecha se almacena internamente como un número positivo y una fecha anterior a esa fecha se referencia como un número negativo.

De forma predeterminada, una fecha se escribe en el formato "AAAA.MM.DD"

q)x:2015.01.22      / This is how we write 22nd Jan 2015

q)`int$x            / Number of days since 2000.01.01
5500i

q)`year$x           / Extracting year from the date
2015i

q)x.year            / Another way of extracting year
2015i

q)`mm$x             / Extracting month from the date
1i

q)x.mm              / Another way of extracting month
1i

q)`dd$x             / Extracting day from the date
22i

q)x.dd              / Another way of extracting day
22i

Arithmetic and logical operations se puede realizar directamente en las fechas.

q)x+1        / Add one day
2015.01.23

q)x-7        / Subtract 7 days
2015.01.15

El 1 de enero de 2000 cayó en sábado. Por lo tanto, cualquier sábado a lo largo de la historia o en el futuro cuando se divide por 7, arrojaría un resto de 0, el domingo da 1, el lunes rinde 2.

Day               mod 7
           Saturday              0
           Sunday                1
           Monday                2
           Tuesday               3
           Wednesday             4
           Thursday              5
           Friday                6

Veces

Una hora se almacena internamente como el número entero de milisegundos desde la medianoche. Una hora se escribe en el formato HH: MM: SS.MSS

q)tt1: 03:30:00.000     / tt1 store the time 03:30 AM

q)tt1
03:30:00.000

q)`int$tt1              / Number of milliseconds in 3.5 hours
12600000i

q)`hh$tt1               / Extract the hour component from time
3i

q)tt1.hh
3i

q)`mm$tt1               / Extract the minute component from time
30i

q)tt1.mm
30i

q)`ss$tt1               / Extract the second component from time
0i

q)tt1.ss
0i

Como en el caso de las fechas, la aritmética se puede realizar directamente en tiempos.

Fechas

Una fecha y hora es la combinación de una fecha y una hora, separadas por 'T' como en el formato estándar ISO. Un valor de fecha y hora almacena el recuento fraccionario de días desde la medianoche del 1 de enero de 2000.

q)dt:2012.12.20T04:54:59:000      / 04:54.59 AM on 20thDec2012

q)type dt
-15h

q)dt
2012.12.20T04:54:59.000
9
q)`float$dt
4737.205

El recuento de días fraccionarios subyacente se puede obtener lanzando para flotar.