64 lines
2.8 KiB
Markdown
64 lines
2.8 KiB
Markdown
---
|
||
title: "⏱ DATETIME 'now' по локальному времени в SQLite"
|
||
date: 2023-01-23T22:50:05+03:00
|
||
draft: false
|
||
tags: [sql, tips]
|
||
---
|
||
|
||
## DATETIME в SQLite
|
||
|
||
В базах данных часто используется дефолтные значения,
|
||
которые подставляются автоматически, если в операции `INSERT`
|
||
значение не указано.
|
||
|
||
Например у тебя есть таблица, в которой поле `join_date`
|
||
имеет тип данных `DATETIME`, значение по умолчанию которого `DATETIME('now')`.
|
||
|
||
```sql
|
||
CREATE TABLE IF NOT EXISTS users(
|
||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||
user_name TEXT NOT NULL,
|
||
join_date DATETIME NOT NULL DEFAULT ( DATETIME('now' ) )
|
||
);
|
||
```
|
||
|
||
В случает добавления записи в таблицу в поле `join_date`
|
||
автоматически будет подставлено текущее время.
|
||
|
||
В документации SQLite написано, что функция `datetime()` возращает значение
|
||
в виде текста в формате `ГГГГ-ММ-ДД ЧЧ:ММ:СС`.
|
||
|
||
> The `datetime()` function returns the date and time as text in their same formats: YYYY-MM-DD HH:MM:SS.
|
||
|
||
Значения даты и времени могут быть сохранены в трех форматах:
|
||
|
||
* текст в подмножестве формата ISO-8601
|
||
* числа представляющие Юлианский день
|
||
* числа представляющие количество секунд с момента (или до) 1970-01-01 00:00:00 UTC (временная метка unix).
|
||
|
||
Время во всех форматах представляется в UTC.
|
||
|
||
## Модификаторы
|
||
|
||
Функция `datetime()` имеет следующий синтаксис.
|
||
|
||
```c++
|
||
datetime(value, modifier)
|
||
```
|
||
|
||
В данном случает в качетсве значения (`value`) используется `now`.
|
||
Список всех значений можно посмотреть на сайте SQLite:
|
||
[https://www.sqlite.org/lang_datefunc.html#time_values](https://www.sqlite.org/lang_datefunc.html#time_values).
|
||
|
||
Для того, чтобы функция вставляла в запись значение даты,
|
||
которое соответсвует локальному времени, необходим модификатор `localtime`.
|
||
|
||
```sql
|
||
CREATE TABLE IF NOT EXISTS users(
|
||
join_date DATETIME NOT NULL DEFAULT ( DATETIME('now', 'localtime') )
|
||
);
|
||
```
|
||
|
||
Список всех модификаторах доступен по этой ссылке:
|
||
[https://www.sqlite.org/lang_datefunc.html#modifiers](https://www.sqlite.org/lang_datefunc.html#modifiers).
|