Datetime-datatypen

Gegevenstypen en functies in Snowflake

Jake Roach

Field Data Engineer

DATE-datatypen

  • Date-waarden slaan de dag op waarop iets gebeurde
                            2023-04-01
                            YYYY-MM-DD
  CREATE TABLE sales (
      transaction_date DATE  -- Define a column of type `DATE`
  );
Gegevenstypen en functies in Snowflake

DATE-datatypen

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
Gegevenstypen en functies in Snowflake

Time-datatypen

  • Legt de uren, minuten en seconden vast waarop iets gebeurde
                               08:24:08
                               HH:MM:SS
CREATE TABLE sales (
    transaction_time TIME  -- Create a column with the `TIME` keyword
);
  • Definieer een TIME-kolom
Gegevenstypen en functies in Snowflake

Time-datatypen

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   |
  • TO_TIME-functie
  • Cast met ::
Gegevenstypen en functies in Snowflake

Timestamp-datatypen

  • TIMESTAMP bevat zowel datum als tijd
                        2023-04-01 08:24:04
                        YYYY-MM-DD HH:MM:SS
CREATE TABLE (
    transaction_timestamp TIMESTAMP
);
Gegevenstypen en functies in Snowflake

Timestamp-datatypen

SELECT 
    TO_TIMESTAMP('2023-04-01 08:24:04') AS the_timestamp,
    '2023-04-01 08:24:04'::TIMESTAMP AS casted_timestamp          
;
  • Zet een string om naar een timestamp met TO_TIMESTAMP of <value>::TIMESTAMP
  • Meest gebruikelijke opslag voor datetime-gegevens
                  the_timestamp     |    casted_timestamp     
              --------------------- | ----------------------  
               2024-04-01 08:24:08  |  2024-04-01 08:24:08    
Gegevenstypen en functies in Snowflake

Voorbeelden

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
Gegevenstypen en functies in Snowflake

Tijdzones

Standaard worden DATE, TIME en TIMESTAMP opgeslagen zonder tijdzone

$$

TIMESTAMP_NTZ

  • Standaardimplementatie van TIMESTAMP
  • Geen tijdzone opgeslagen

$$

TIMESTAMP_LTZ

  • Gebruikt de lokale tijdzone

$$

TIMESTAMP_TZ

  • Gebruiker stelt tijdzone in
1 https://docs.snowflake.com/en/sql-reference/data-types-datetime#timestamp-ltz-timestamp-ntz-timestamp-tz
Gegevenstypen en functies in Snowflake

Laten we oefenen!

Gegevenstypen en functies in Snowflake

Preparing Video For Download...