Datum-/tijdtypen in BigQuery

Introductie tot BigQuery

Matt Forrest

Field CTO

Waarom datums en tijden belangrijk zijn

  1. Lange datasets makkelijk filteren
  2. Onderdelen van datums/tijden extraheren
  3. Partitie-strategieën
Introductie tot BigQuery

Datums

Voorbeeld van het datatype DATE

SELECT 
    DATE(2010, 05, 19) as launch


/*------------* | launch | +------------+ | 2010-05-19 | *------------*/
Introductie tot BigQuery

Timestamps

Voorbeeld van een timestamp:

SELECT 
    TIMESTAMP("2010-05-19 00:00:00+00") as launch


/*-------------------------* | launch | +-------------------------+ | 2010-05-19 00:00:00 UTC | *-------------------------*/
Introductie tot BigQuery

Datetime en Time

Voorbeelden van time en datetime:

SELECT
  TIME(12, 00, 00) as noon,

DATETIME(2019, 05, 19, 00, 00, 00) as launch
/*----------+----------------------* | noon | launch | +----------+----------------------+ | 12:00:00 | 2019-05-19T00:00:00 | *----------+----------------------*/
Introductie tot BigQuery

Datum- en timestamp-onderdelen

Dag

  • DAY, DAYOFWEEK, DAYOFYEAR.

Week

  • WEEK, WEEKDAY, ISOWEEK.

Maand/jaar

  • MONTH, QUARTER, YEAR, ISOYEAR.

Tijd

  • HOUR, MINUTE, SECOND, MILLISECOND, MICROSECOND.
1 https://cloud.google.com/bigquery/docs/reference/standard-sql/timestamp_functions#timestamp_trunc
Introductie tot BigQuery

ADD, SUBTRACT en DIFF

Vijf dagen toevoegen

SELECT 
    DATE_ADD(DATE '2010-05-19', 
             INTERVAL 5 DAY) 
             AS five_days_later;

/*--------------------* | five_days_later | +--------------------+ | 2010-05-24 | *--------------------*/

Het verschil vinden

SELECT 
    DATE_DIFF(DATE '2010-05-24', 
             DATE '2010-05-19', DAY) 
             AS difference;


/*-------------* | difference | +-------------+ | 5 | *-------------*/
Introductie tot BigQuery

EXTRACT

Weekdag bepalen

SELECT 
    EXTRACT(DAYOFWEEK FROM DATE '2010-05-19') 
             AS day_of_week;


/*--------------* | day_of_week | +--------------+ | 4 | *--------------*/
Introductie tot BigQuery

FORMAT

SELECT
    FORMAT_DATE(
      '%x', DATE '2010-05-19') 
    AS with_slashes;


/*--------------* | with_slashes | +--------------+ | 05/19/10 | *--------------*/
SELECT
    FORMAT_DATE(
      '%A', DATE '2010-05-19') 
    AS dow;

/*--------------* | dow | +--------------+ | Wednesday | *--------------*/
1 https://cloud.google.com/bigquery/docs/reference/standard-sql/format-elements#format_elements_date_time
Introductie tot BigQuery

Huidige datum/timestamp

Huidige timestamp vinden:

SELECT
  CURRENT_TIMESTAMP(); 

/*---------------------------------*
 | current_timestamp               |
 +---------------------------------+
 | 2023-11-13 17:35:25.951432 UTC  |
 *---------------------------------*/

Huidige datum vinden:

SELECT
  CURRENT_DATE();

/*---------------*
 | current_date  |
 +---------------+
 | 2023-11-13    |
 *---------------*/
Introductie tot BigQuery

Spiekbrief

Datatypen

  • Datums zijn exacte dagen; timestamps zijn absolute datum en tijd

Datum-/tijddelen

  • Onderdelen van een datum/timestamp (bijv. MONTH of HOUR)

Optellen en aftrekken

  • Functies om delen toe te voegen of af te trekken (bijv. DATE_ADD)

Verschil

  • Verschil tussen twee datums per deel (bijv. TIMESTAMP_SUB)

Extract en format

  • Een deel uit een datum halen en een datum opmaken (bijv. EXTRACT en FORMAT)

Huidige datum/timestamp

  • De huidige datum of timestamp retourneren (bijv. CURRENT_TIMESTAMP)
Introductie tot BigQuery

Laten we oefenen!

Introductie tot BigQuery

Preparing Video For Download...