Níže jsou uvedeny 4 funkce, které vám umožňují vrátit část minut z časové hodnoty v MariaDB.
MINUTE() Funkce
MINUTE() funkce vrací minutovou část daného TIME nebo DATETIME výraz. Přijímá jeden argument, což je čas, ze kterého chcete extrahovat minuty.
Příklad:
SELECT MINUTE('03:45:30'); Výsledek:
+--------------------+
| MINUTE('03:45:30') |
+--------------------+
| 45 |
+--------------------+
TIME hodnoty mohou být v rozsahu '-838:59:59.999999' na '838:59:59.999999' . Takže, ačkoli část hodin může být mnohem vyšší než 23 , část minut může být pouze v rozsahu 0 až 59 .
TIME hodnoty mohou být i záporné. V takových případech MINUTE() vrátí kladnou hodnotu.
Zde je záporná časová hodnota s větší hodinovou částí:
SELECT MINUTE('-838:59:59'); Výsledek:
+----------------------+
| MINUTE('-838:59:59') |
+----------------------+
| 59 |
+----------------------+ Část minut je extrahována podle očekávání.
EXTRACT() Funkce
EXTRACT() Funkce umožňuje extrahovat zadanou jednotku z hodnoty data/času. Proto jej můžete použít k extrahování minut (stejně jako jiných jednotek) z časové hodnoty.
Příklad:
SELECT EXTRACT(MINUTE FROM '10:47:01'); Výsledek:
+---------------------------------+ | EXTRACT(MINUTE FROM '10:47:01') | +---------------------------------+ | 47 | +---------------------------------+
TIME_FORMAT() Funkce
TIME_FORMAT() Funkce umožňuje formátovat časovou hodnotu na základě formátovacího řetězce. Formátovací řetězec určuje, jak má být formátován čas.
Tuto funkci tedy můžete použít k vrácení minut (a také hodin a sekund) od času.
Pomocí %i specifikátor formátu vrací minuty se dvěma číslicemi:
SELECT TIME_FORMAT('10:07:30', '%i'); Výsledek:
+-------------------------------+
| TIME_FORMAT('10:07:30', '%i') |
+-------------------------------+
| 07 |
+-------------------------------+
TIME_FORMAT() funkce přijímá podmnožinu formátovacích řetězců, které lze použít s DATE_FORMAT() funkce. Úplný seznam formátovacích řetězců/specifikátorů, které lze použít s DATE_FORMAT(), najdete v části MariaDB Format Strings . TIME_FORMAT() funkce přijímá pouze specifikátory formátu pro hodiny, minuty a sekundy. Jakýkoli jiný specifikátor formátu má za následek null nebo 0 se vrací.
DATE_FORMAT() Funkce
DATE_FORMAT() Funkce umožňuje formátovat hodnotu data nebo data a času na základě formátovacího řetězce. Formátovací řetězec určuje, jak má být formátován datum/čas.
Můžeme tedy použít stejné specifikátory formátu, které jsme použili u TIME_FORMAT() funkce v předchozím příkladu. Nicméně DATE_FORMAT() nepřijímá TIME hodnotu, takže budeme muset předat DATETIME hodnotu.
SELECT DATE_FORMAT('2023-01-01 10:07:30', '%i'); Výsledek:
+------------------------------------------+
| DATE_FORMAT('2023-01-01 10:07:30', '%i') |
+------------------------------------------+
| 07 |
+------------------------------------------+
Předání jen TIME value s touto funkcí nefunguje:
SELECT DATE_FORMAT('10:07:30', '%i') AS '%i'; Výsledek:
+------+ | %i | +------+ | 00 | +------+