extract Funkcja

Dotyczy:sprawdź oznaczone jako tak Zaznaczone pole wyboru SQL usługi Databricks oznaczone jako tak Databricks Runtime

Zwraca wartość field .source

Składni

extract(field FROM source)

Argumenty

  • field: słowo kluczowe, które wybiera część source , która ma zostać wyodrębniona.
  • source: wyrażenie DATE, TIMESTAMPlub INTERVAL .

Zwraca

Jeśli field parametr ma SECONDwartość , a DECIMAL(8, 6). We wszystkich pozostałych przypadkach element INTEGER.

Obsługiwane wartości parametru field , gdy source jest lub DATETIMESTAMP:

  • YEAR, , Y, YEARS, YRSYR: pole roku
  • YEAROFWEEK: rok numerowania tygodniowego ISO 8601, w przypadku którego przypada data/godzina. Na przykład 2005-01-02 jest częścią 53 tygodnia roku 2004, więc wynik to 2004
  • QUARTER, QTR: kwartał (1–4) roku, w ramach którego przypada data/godzina
  • MONTH, , MON, MONTHSMONS: pole miesiąca (1–12)
  • WEEK, , WWEEKS: liczba iso 8601 tydzień tygodnia na podstawie roku. Uważa się, że tydzień rozpoczyna się w poniedziałek i tydzień 1 jest pierwszym tygodniem z >3 dniami. W systemie numerowania tygodni ISO daty na początku stycznia mogą być częścią 52. lub 53. tygodnia poprzedniego roku, a daty z końca grudnia mogą być częścią pierwszego tygodnia następnego roku. Na przykład 2005-01-02 jest częścią 53 tygodnia roku 2004, podczas gdy 2012-12-31 jest częścią pierwszego tygodnia 2013
  • DAY, , DDAYS: dzień pola miesiąca (1–31)
  • DAYOFWEEK, DOW: dzień tygodnia dla daty/godziny jako niedziela(1) do soboty (7)
  • DAYOFWEEK_ISO, DOW_ISO: iso 8601 na podstawie dnia tygodnia dla daty/godziny w poniedziałek(1) do niedzieli(7)
  • DOY: dzień roku (1 – 365/366)
  • HOUR, , H, HOURS, HRSHR: pole godziny (0–23)
  • MINUTE, , M, MIN, MINUTESMINS: pole minut (0–59)
  • SECOND, , S, SECONDSSEC, SECS: pole sekund, w tym części ułamkowe

Obsługiwane wartości parametru field when source is INTERVAL (bez uwzględniania wielkości liter):

  • YEAR, , Y, YRYEARS, YRS: łączna liczba miesięcy / 12
  • MONTH, , MON, MONTHSMONS: suma miesięcy % 12
  • DAY, , DAYS: Dczęść interwału dni
  • HOUR, , H, HOURS, HRSHR: ile godzin zawiera mikrosekundy
  • MINUTE, , M, MIN, MINUTESMINS: ile minut pozostało po godzinach od mikrosekund
  • SECOND, , S, SEC, SECSSECONDS: ile sekund z ułamkami pozostało po godzinach i minutach od mikrosekund

Przykłady

> SELECT extract(YEAR FROM TIMESTAMP '2019-08-12 01:00:00.123456');
 2019

> SELECT extract(week FROM TIMESTAMP'2019-08-12 01:00:00.123456');
 33

> SELECT extract(DAY FROM DATE'2019-08-12');
 12

> SELECT extract(SECONDS FROM TIMESTAMP'2019-10-01 00:00:01.000001');
 1.000001

> SELECT extract(MONTHS FROM INTERVAL '2-11' YEAR TO MONTH);
 11

> SELECT extract(SECONDS FROM INTERVAL '5:00:30.001' HOUR TO SECOND);
 30.001000