Tipi di dati datetime

Tipi di dati e funzioni in Snowflake

Jake Roach

Field Data Engineer

Tipi di dati DATE

  • I valori Date indicano il giorno in cui è avvenuto qualcosa
                            2023-04-01
                            YYYY-MM-DD
  CREATE TABLE sales (
      transaction_date DATE  -- Define a column of type `DATE`
  );
Tipi di dati e funzioni in Snowflake

Tipi di dati DATE

SELECT

TO_DATE('2023-04-01') AS the_date, -- Convert a string into a DATE
'2023-04-01'::DATE AS casted_date -- Casted using <value>::DATE
;
                         the_date  | casted_date  
                       ----------- | ------------  
                        2023-04-01 | 2023-04-01
Tipi di dati e funzioni in Snowflake

Tipi di dati Time

  • Rappresenta ore, minuti e secondi in cui è avvenuto un evento
                               08:24:08
                               HH:MM:SS
CREATE TABLE sales (
    transaction_time TIME  -- Create a column with the `TIME` keyword
);
  • Definisci una colonna TIME
Tipi di dati e funzioni in Snowflake

Tipi di dati Time

SELECT

TO_TIME('08:24:04') AS the_time,
'08:24:04'::TIME AS casted_time
;
                     |  the_time  | casted_time |
                     | ---------- | ----------- |
                     |  08:24:08  |  08:24:08   |
  • Funzione TO_TIME
  • Cast con ::
Tipi di dati e funzioni in Snowflake

Tipi di dati timestamp

  • TIMESTAMP include data e ora
                        2023-04-01 08:24:04
                        YYYY-MM-DD HH:MM:SS
CREATE TABLE (
    transaction_timestamp TIMESTAMP
);
Tipi di dati e funzioni in Snowflake

Tipi di dati timestamp

SELECT 
    TO_TIMESTAMP('2023-04-01 08:24:04') AS the_timestamp,
    '2023-04-01 08:24:04'::TIMESTAMP AS casted_timestamp          
;
  • Converte una stringa in timestamp con TO_TIMESTAMP o <value>::TIMESTAMP
  • Modo più comune per salvare dati datetime
                  the_timestamp     |    casted_timestamp     
              --------------------- | ----------------------  
               2024-04-01 08:24:08  |  2024-04-01 08:24:08    
Tipi di dati e funzioni in Snowflake

Esempi

SELECT
    TO_DATE('2021-05-14') AS the_date,
    TO_TIME('06:13:00') AS the_time,
    TO_TIMESTAMP('2021-05-14T06:13:00') AS the_timestamp,


-- Extract the DATE from a TIMESTAMP, we could do the same with TIME! transaction_timestamp::DATE AS casted_date
;
           the_date   |   the_time  |     the_timestamp    | casted_date  
         ------------ | ----------- | -------------------- | ------------  
          2021-05-14  |   06:13:00  | 2021-05-14T06:13:00  |  2021-05-14
Tipi di dati e funzioni in Snowflake

Fusi orari

Per impostazione predefinita, DATE, TIME e TIMESTAMP sono salvati senza fuso orario

$$

TIMESTAMP_NTZ

  • Implementazione predefinita di TIMESTAMP
  • Nessun fuso orario salvato

$$

TIMESTAMP_LTZ

  • Usa il fuso orario locale

$$

TIMESTAMP_TZ

  • L'utente specifica il fuso orario
1 https://docs.snowflake.com/en/sql-reference/data-types-datetime#timestamp-ltz-timestamp-ntz-timestamp-tz
Tipi di dati e funzioni in Snowflake

Passons à la pratique !

Tipi di dati e funzioni in Snowflake

Preparing Video For Download...