Работа с датой и временем в mysql

Пример

Рассмотрим несколько примеров функции TO_CHAR и изучим, как использовать функцию TO_CHAR в Oracle/PLSQL.

Для чисел

Ниже приведены примеры для функции TO_CHAR для чисел.

Oracle PL/SQL

SQL> SELECT TO_CHAR(1242.78, ‘9999.9’) FROM DUAL;

—Результат: 1242.8

SQL> SELECT TO_CHAR(-1242.78, ‘9999.9’) FROM DUAL;

—Результат: -1242.8

SQL> SELECT TO_CHAR(1242.78, ‘9,999.99’) FROM DUAL;

—Результат: 1,242.78

SQL> SELECT TO_CHAR(1242.78, ‘$9,999.00’) FROM DUAL;

—Результат: $1,242.78

SQL> SELECT TO_CHAR(18, ‘000099’) FROM DUAL;

—Результат: 000018

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

SQL>SELECTTO_CHAR(1242.78,’9999.9′)FROMDUAL;
 
—Результат:    1242.8
 

SQL>SELECTTO_CHAR(-1242.78,’9999.9′)FROMDUAL;
 
—Результат:   -1242.8
 

SQL>SELECTTO_CHAR(1242.78,’9,999.99′)FROMDUAL;
 
—Результат:    1,242.78
 

SQL>SELECTTO_CHAR(1242.78,’$9,999.00′)FROMDUAL;
 
—Результат:   $1,242.78
 

SQL>SELECTTO_CHAR(18,’000099′)FROMDUAL;
 
—Результат:    000018

Для дат

Ниже приведен список допустимых параметров, когда функция TO_CHAR используется для преобразования даты в строку. Эти параметры могут быть использованы во многих комбинациях.

Параметр Пояснение
YEAR Год.
YYYY 4-значный год.
YYY YY Y Последние 3, 2 или 1 цифра(ы) года.
IYY IY I Последние 3, 2 или 1 цифра(ы) года ISO.
IYYY 4-значный год в соответствии со стандартом ISO.
Q Квартал года (1, 2, 3, 4; JAN-MAR = 1).
MM Месяц (01-12; JAN = 01).
MON Сокращенное название месяца.
MONTH Название месяца, дополненное пробелами длиной до 9 символов.
RM Римская цифра RM (I-XII; JAN = I).
WW Неделя года (1-53), где неделя 1 начинается в первый день года и продолжается до седьмого дня года.
W Неделя месяца (1-5), где неделя 1 начинается в первый день месяца и заканчивается седьмым.
IW Неделя года (1-52 или 1-53) на основе стандарта ISO.
D День недели (1-7).
DAY Название дня.
DD День месяца (1-31).
DDD День года (1-366).
DY Сокращенное название дня.
J юлианский день; количество дней с 1 января 4712 г. до н.э.
HH Час дня (1-12).
HH12 Час дня (1-12).
HH24 Час дня (0-23).
MI Минуты (0-59).
SS Секунды (0-59).
SSSSS Секунды после полуночи (0-86399).
FF Дробные секунды.

Ниже приведены примеры функции TO_CHAR для дат.

Oracle PL/SQL

SQL> SELECT TO_CHAR(sysdate, ‘yyyy/mm/dd’) FROM DUAL;

—Результат: 2014/08/28

SQL> SELECT TO_CHAR(sysdate, ‘yyyy.mm.dd’) FROM DUAL;

—Результат: 2014.08.28

SQL> SELECT TO_CHAR(sysdate, ‘Month DD, YYYY’) FROM DUAL;

—Результат: Август 28, 2014

SQL> SELECT TO_CHAR(sysdate, ‘FMMonth DD, YYYY’) FROM DUAL;

—Результат: Август 28, 2014

SQL> SELECT TO_CHAR(sysdate, ‘MON DDth, YYYY’) FROM DUAL;

—Результат: АВГ 28TH, 2014

SQL> SELECT TO_CHAR(sysdate, ‘FMMON DDth, YYYY’) FROM DUAL;

—Результат: АВГ 28TH, 2014

SQL> SELECT TO_CHAR(sysdate, ‘FMMon ddth, YYYY’) FROM DUAL;

—Результат: Авг 28th, 2014

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

SQL>SELECTTO_CHAR(sysdate,’yyyy/mm/dd’)FROMDUAL;
 
—Результат:   2014/08/28
 

SQL>SELECTTO_CHAR(sysdate,’yyyy.mm.dd’)FROMDUAL;
 
—Результат:   2014.08.28
 

SQL>SELECTTO_CHAR(sysdate,’Month DD, YYYY’)FROMDUAL;
 
—Результат:   Август   28, 2014
 

SQL>SELECTTO_CHAR(sysdate,’FMMonth DD, YYYY’)FROMDUAL;
 
—Результат:   Август 28, 2014
 

SQL>SELECTTO_CHAR(sysdate,’MON DDth, YYYY’)FROMDUAL;
 
—Результат:   АВГ 28TH, 2014
 

SQL>SELECTTO_CHAR(sysdate,’FMMON DDth, YYYY’)FROMDUAL;
 
—Результат:   АВГ 28TH, 2014
 

SQL>SELECTTO_CHAR(sysdate,’FMMon ddth, YYYY’)FROMDUAL;
 
—Результат:   Авг 28th, 2014

Вы заметите, что в некоторых примерах функции TO_CHAR, параметр format_mask начинается с ‘FM’. Это означает, что нули и пробелы подавлены. Это можно увидеть в приведенных ниже примерах.

Oracle PL/SQL

SQL> SELECT TO_CHAR(SYSDATE, ‘FMMonth DD, YYYY’) FROM DUAL;

—Результат: Август 9, 2014

SQL> SELECT TO_CHAR(SYSDATE, ‘FMMON DDth, YYYY’) FROM DUAL;

—Результат: АВГ 9TH, 2014

SQL> SELECT TO_CHAR(SYSDATE, ‘FMMon ddth, YYYY’) FROM DUAL;

—Результат: Авг 9th, 2014

1
2
3
4
5
6
7
8
9
10
11

SQL>SELECTTO_CHAR(SYSDATE,’FMMonth DD, YYYY’)FROMDUAL;
 
—Результат:   Август 9, 2014
 

SQL>SELECTTO_CHAR(SYSDATE,’FMMON DDth, YYYY’)FROMDUAL;
 
—Результат:   АВГ 9TH, 2014
 

SQL>SELECTTO_CHAR(SYSDATE,’FMMon ddth, YYYY’)FROMDUAL;
 
—Результат:   Авг 9th, 2014

Нули были подавлены, так что день показывает, как «9», а не «09».

Дополнительная информация

получен из и происходит от . Они устанавливаются, когда вы изначально создали базу данных, но их можно изменить, изменив файл параметров инициализации — только если это действительно необходимо — или на уровне сеанса с помощью . Например:

Это означает:

  • числовой день месяца, 1 — 31
  • числовой месяц года, 01 — 12 (январь 01)
  • 4-значный год — по-моему, это всегда лучше, чем двухзначный год , поскольку нет путаницы с тем, о каком веке вы имеете в виду.
  • час дня, 0 — 23
  • минута часа, 0 — 59
  • секунда минуты, 0-59

Вы можете узнать свои текущие настройки языка и языка дат, запросив и полную гамму допустимых значений, запросив .

5 ответов

211

не является строкой и не является . Они — цифры с добавлением дополнительного материала в конце. Это должно быть или — отметить одиночную кавычку . Это позволит вам выполнить сравнение строк.

Однако вы не выполняете сравнение строк; вы делаете сравнение даты. Вы должны преобразовать строку в дату. Либо используя встроенную функцию , либо .

TO_DATE()

Этот метод имеет несколько ненужных ошибок

  • Как отмечалось в комментариях a_horse_with_no_name, , не обязательно означает декабрь. Это зависит от настроек и , Чтобы убедиться, что ваше сравнение с работой в любой локали вы можете использовать вместо
  • Год ’95 неточный. Вы знаете, что вы имеете в виду 1995 год, но что, если это было 50 лет, это 1950 или 2050 год? Всегда лучше быть явным.

Литералы даты

Литерал даты является частью стандарта ANSI, что означает, что вам не нужно использовать специальную функцию Oracle. При использовании литерала вы должны указать свою дату в формате , и вы не можете включить элемент времени.

Помните, что тип данных даты Oracle включает элемент времени, поэтому дата без временной части эквивалентна .

Если вы хотите включить временную часть, вам придется использовать литерал timestamp, который принимает формат

Дополнительная информация

получен из и происходит от . Они устанавливаются, когда вы изначально создали базу данных, но их можно изменить, изменив файл параметров инициализации — только если это действительно необходимо — или на уровне сеанса с помощью . Например:

Это означает:

  • числовой день месяца, 1 — 31
  • числовой месяц года, 01 — 12 (январь 01)
  • 4-значный год — по-моему, это всегда лучше, чем двухзначный год , поскольку нет путаницы с тем, о каком веке вы имеете в виду.
  • час дня, 0 — 23
  • минута часа, 0 — 59
  • секунда минуты, 0-59

Вы можете узнать свои текущие настройки языка и языка дат, запросив и полную гамму допустимых значений, запросив .

Дальнейшее чтение

Форматировать модели

Кстати, если вы хотите , вам нужно сгруппировать по

Это дает вам счет за .

16 апр. 2012, в 17:24
Поделиться

3

Вывод

работает по-своему

Итак,

Всегда используйте этот формат ГГГГ-ММ-ДД для сравнения
вместо MM-DD-YY или DD-MM-YYYY или любого другого формата

11 нояб. 2014, в 13:44
Поделиться

2

из вашего запроса:

Я думаю, что он не отображает число сотрудников, нанятых после 20 июня 1994 года. Если вы хотите показать количество сотрудников, вы можете использовать:

Я думаю, что для лучшей практики сравнить даты, которые вы можете использовать:

03 дек. 2015, в 10:41
Поделиться

2

Вы можете использовать trunc и to_date следующим образом:

03 фев. 2015, в 22:48
Поделиться

-4

Одинарная кавычка должна быть там, так как дата конвертирована в символ.

Select employee_id, count(*)
From Employee
Where to_char(employee_date_hired, 'DD-MON-YY') > '31-DEC-95';

19 июнь 2014, в 08:00
Поделиться

SQL Справочник

SQL Ключевые слова
ADD
ADD CONSTRAINT
ALTER
ALTER COLUMN
ALTER TABLE
ALL
AND
ANY
AS
ASC
BACKUP DATABASE
BETWEEN
CASE
CHECK
COLUMN
CONSTRAINT
CREATE
CREATE DATABASE
CREATE INDEX
CREATE OR REPLACE VIEW
CREATE TABLE
CREATE PROCEDURE
CREATE UNIQUE INDEX
CREATE VIEW
DATABASE
DEFAULT
DELETE
DESC
DISTINCT
DROP
DROP COLUMN
DROP CONSTRAINT
DROP DATABASE
DROP DEFAULT
DROP INDEX
DROP TABLE
DROP VIEW
EXEC
EXISTS
FOREIGN KEY
FROM
FULL OUTER JOIN
GROUP BY
HAVING
IN
INDEX
INNER JOIN
INSERT INTO
INSERT INTO SELECT
IS NULL
IS NOT NULL
JOIN
LEFT JOIN
LIKE
LIMIT
NOT
NOT NULL
OR
ORDER BY
OUTER JOIN
PRIMARY KEY
PROCEDURE
RIGHT JOIN
ROWNUM
SELECT
SELECT DISTINCT
SELECT INTO
SELECT TOP
SET
TABLE
TOP
TRUNCATE TABLE
UNION
UNION ALL
UNIQUE
UPDATE
VALUES
VIEW
WHERE

MySQL Функции
Функции строк
ASCII
CHAR_LENGTH
CHARACTER_LENGTH
CONCAT
CONCAT_WS
FIELD
FIND_IN_SET
FORMAT
INSERT
INSTR
LCASE
LEFT
LENGTH
LOCATE
LOWER
LPAD
LTRIM
MID
POSITION
REPEAT
REPLACE
REVERSE
RIGHT
RPAD
RTRIM
SPACE
STRCMP
SUBSTR
SUBSTRING
SUBSTRING_INDEX
TRIM
UCASE
UPPER
Функции чисел
ABS
ACOS
ASIN
ATAN
ATAN2
AVG
CEIL
CEILING
COS
COT
COUNT
DEGREES
DIV
EXP
FLOOR
GREATEST
LEAST
LN
LOG
LOG10
LOG2
MAX
MIN
MOD
PI
POW
POWER
RADIANS
RAND
ROUND
SIGN
SIN
SQRT
SUM
TAN
TRUNCATE
Функции дат
ADDDATE
ADDTIME
CURDATE
CURRENT_DATE
CURRENT_TIME
CURRENT_TIMESTAMP
CURTIME
DATE
DATEDIFF
DATE_ADD
DATE_FORMAT
DATE_SUB
DAY
DAYNAME
DAYOFMONTH
DAYOFWEEK
DAYOFYEAR
EXTRACT
FROM_DAYS
HOUR
LAST_DAY
LOCALTIME
LOCALTIMESTAMP
MAKEDATE
MAKETIME
MICROSECOND
MINUTE
MONTH
MONTHNAME
NOW
PERIOD_ADD
PERIOD_DIFF
QUARTER
SECOND
SEC_TO_TIME
STR_TO_DATE
SUBDATE
SUBTIME
SYSDATE
TIME
TIME_FORMAT
TIME_TO_SEC
TIMEDIFF
TIMESTAMP
TO_DAYS
WEEK
WEEKDAY
WEEKOFYEAR
YEAR
YEARWEEK
Функции расширений
BIN
BINARY
CASE
CAST
COALESCE
CONNECTION_ID
CONV
CONVERT
CURRENT_USER
DATABASE
IF
IFNULL
ISNULL
LAST_INSERT_ID
NULLIF
SESSION_USER
SYSTEM_USER
USER
VERSION

SQL Server функции
Функции строк
ASCII
CHAR
CHARINDEX
CONCAT
Concat with +
CONCAT_WS
DATALENGTH
DIFFERENCE
FORMAT
LEFT
LEN
LOWER
LTRIM
NCHAR
PATINDEX
QUOTENAME
REPLACE
REPLICATE
REVERSE
RIGHT
RTRIM
SOUNDEX
SPACE
STR
STUFF
SUBSTRING
TRANSLATE
TRIM
UNICODE
UPPER
Функции чисел
ABS
ACOS
ASIN
ATAN
ATN2
AVG
CEILING
COUNT
COS
COT
DEGREES
EXP
FLOOR
LOG
LOG10
MAX
MIN
PI
POWER
RADIANS
RAND
ROUND
SIGN
SIN
SQRT
SQUARE
SUM
TAN
Функции дат
CURRENT_TIMESTAMP
DATEADD
DATEDIFF
DATEFROMPARTS
DATENAME
DATEPART
DAY
GETDATE
GETUTCDATE
ISDATE
MONTH
SYSDATETIME
YEAR
Функции расширений
CAST
COALESCE
CONVERT
CURRENT_USER
IIF
ISNULL
ISNUMERIC
NULLIF
SESSION_USER
SESSIONPROPERTY
SYSTEM_USER
USER_NAME

MS Access функции
Функции строк
Asc
Chr
Concat with &
CurDir
Format
InStr
InstrRev
LCase
Left
Len
LTrim
Mid
Replace
Right
RTrim
Space
Split
Str
StrComp
StrConv
StrReverse
Trim
UCase
Функции чисел
Abs
Atn
Avg
Cos
Count
Exp
Fix
Format
Int
Max
Min
Randomize
Rnd
Round
Sgn
Sqr
Sum
Val
Функции дат
Date
DateAdd
DateDiff
DatePart
DateSerial
DateValue
Day
Format
Hour
Minute
Month
MonthName
Now
Second
Time
TimeSerial
TimeValue
Weekday
WeekdayName
Year
Другие функции
CurrentUser
Environ
IsDate
IsNull
IsNumeric

SQL ОператорыSQL Типы данныхSQL Краткий справочник

Работа со временем высокой точности в MySQL

MySQL поддерживает три типа колонок, в которых можно хранить время: , и . Изначально в них можно было хранить только значения, кратные одной секунде (например, 2019-08-14 19:20:21). В версии 5.6.4, которая вышла в декабре 2011 года, появилась возможность работать и с дробной частью секунды. Для этого при создании колонки нужно указать количество знаков после запятой, которое необходимо хранить в дробной части метки времени. Максимальное количество знаков, которое поддерживается, — шесть, что позволяет хранить время с точностью до микросекунды. При попытке использовать большее количество знаков вы получите ошибку.

Пример:

В этом примере у метки времени вставленной записи нулевая дробная часть. Это произошло потому, что входящее значение было указано с точностью до секунды. Для решения проблемы нужно, чтобы точность входящего значения была такой же, как у значения в базе данных. Совет кажется очевидным, но он актуален, поскольку подобная проблема может всплыть в реальных приложениях: мы сталкивались с ситуацией, когда значение на входе имело три знака после запятой, а в базе данных хранилось шесть.

Самый простой способ предупредить возникновение этой проблемы — использовать входящие значения с максимальной точностью (до микросекунды). В этом случае при записи данных в таблицу время округлится до требуемой точности. Это абсолютно нормальная ситуация, которая не будет вызывать никаких warning-ов (предупреждений):

При использовании автоматической инициализации и автоматического обновления колонок типа TIMESTAMP с помощью конструкции вида важно, чтобы значения имели ту же точность, что и сама колонка:

Функции MySQL для работы со временем поддерживают работу и с дробной частью единиц измерения. Перечислять их все я не буду (предлагаю посмотреть в документации), но приведу несколько примеров:

Главная проблема, с которой сопряжено использование дробной части секунд в SQL-запросах, — несогласованность точности при сравнениях (, , ). С ней можно столкнуться в том случае, если данные в базе имеют одну точность, а в запросах — другую. Вот небольшой пример, иллюстрирующий эту проблему:

В данном примере точность значений в запросе выше, чем точность значений в базе, и проблема возникает «на границе сверху». В обратной ситуации (если значение на входе будет иметь точность ниже, чем значение в базе) проблемы не будет — MySQL приведёт значение к нужной точности и в INSERT-е, и в SELECT-е:

Согласованность точности значений всегда стоит держать в голове при работе со временем высокой точности. Если подобные граничные проблемы для вас критичны, то нужно следить за тем, чтобы код и база данных работали с одинаковым количеством знаков после запятой.

См. также:

  • “Fractional Seconds in Time Values”;
  • “Automatic Initialization and Updating for TIMESTAMP and DATETIME”;
  • “Date and Time Functions”.

SQL Работа с датами

Вы можете сравнить две даты легко, если нет времени компонент участвует!

Предположим , мы имеем следующую «Orders» таблица:

OrderId ProductName OrderDate
1 Geitost 2008-11-11
2 Camembert Pierrot 2008-11-09
3 Mozzarella di Giovanni 2008-11-11
4 Mascarpone Fabioli 2008-10-29

Теперь мы хотим , чтобы выбрать записи с OrderDate из «2008-11-11» из приведенной выше таблицы.

Мы используем следующую ЗЕЬЕСТ:

SELECT * FROM Orders WHERE OrderDate=’2008-11-11′

Результат-набор будет выглядеть следующим образом:

OrderId ProductName OrderDate
1 Geitost 2008-11-11
3 Mozzarella di Giovanni 2008-11-11

Теперь предположим , что «Orders» таблица выглядит следующим образом (обратите внимание на компонент времени в «OrderDate» колонке):

OrderId ProductName OrderDate
1 Geitost 2008-11-11 13:23:44
2 Камамбер Пьерро 2008-11-09 15:45:21
3 Моцарелла ди Джованни 2008-11-11 11:12:01
4 Маскарпоне Fabioli 2008-10-29 14:56:59

Если мы используем один и тот же оператор SELECT, как описано выше:

SELECT * FROM Orders WHERE OrderDate=’2008-11-11′

мы не получим никакого результата! Это происходит потому, что запрос ищет только даты без времени части.

Tip: Если вы хотите сохранить ваши запросы простой и легкий в обслуживании, не позволяют компоненты времени ваши даты!

❮ Предыдущая Следующая Глава ❯

SUBDATE(date,INTERVAL expr unit) and SUBDATE(expr,days)

When invoked with the INTERVAL form of the second argument, SUBDATE() is a synonym for DATE_SUB(). For information on the INTERVAL unit argument, see the discussion for DATE_ADD().

mysql> SELECT DATE_SUB('1998-01-02', INTERVAL 31 DAY);
+---------------------------------------------------------+
| DATE_SUB('1998-01-02', INTERVAL 31 DAY)                 |
+---------------------------------------------------------+
| 1997-12-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT SUBDATE('1998-01-02', INTERVAL 31 DAY);
+---------------------------------------------------------+
| SUBDATE('1998-01-02', INTERVAL 31 DAY)                  |
+---------------------------------------------------------+
| 1997-12-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date)

If called with no argument, this function returns a Unix timestamp (seconds since ‘1970-01-01 00:00:00’ UTC) as an unsigned integer. If UNIX_TIMESTAMP() is called with a date argument, it returns the value of the argument as seconds since ‘1970-01-01 00:00:00’ UTC. date may be a DATE string, a DATETIME string, a TIMESTAMP, or a number in the format YYMMDD or YYYYMMDD.

mysql> SELECT UNIX_TIMESTAMP();
+---------------------------------------------------------+
| UNIX_TIMESTAMP()                                        |
+---------------------------------------------------------+
| 882226357                                               |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT UNIX_TIMESTAMP('1997-10-04 22:23:00');
+---------------------------------------------------------+
| UNIX_TIMESTAMP('1997-10-04 22:23:00')                   |
+---------------------------------------------------------+
| 875996580                                               |
+---------------------------------------------------------+
1 row in set (0.00 sec)

FROM_UNIXTIME(unix_timestamp,format)

Returns a representation of the unix_timestamp argument as a value in ‘YYYY-MM-DD HH:MM:SS or YYYYMMDDHHMMSS format, depending on whether the function is used in a string or in a numeric context. The value is expressed in the current time zone. The unix_timestamp argument is an internal timestamp values, which are produced by the UNIX_TIMESTAMP() function.

If the format is given, the result is formatted according to the format string, which is used in the same way as is listed in the entry for the DATE_FORMAT() function.

mysql> SELECT FROM_UNIXTIME(875996580);
+---------------------------------------------------------+
| FROM_UNIXTIME(875996580)                                |
+---------------------------------------------------------+
| 1997-10-04 22:23:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

SQL Учебник

SQL ГлавнаяSQL ВведениеSQL СинтаксисSQL SELECTSQL SELECT DISTINCTSQL WHERESQL AND, OR, NOTSQL ORDER BYSQL INSERT INTOSQL Значение NullSQL Инструкция UPDATESQL Инструкция DELETESQL SELECT TOPSQL MIN() и MAX()SQL COUNT(), AVG() и …SQL Оператор LIKESQL ПодстановочныйSQL Оператор INSQL Оператор BETWEENSQL ПсевдонимыSQL JOINSQL JOIN ВнутриSQL JOIN СлеваSQL JOIN СправаSQL JOIN ПолноеSQL JOIN СамSQL Оператор UNIONSQL GROUP BYSQL HAVINGSQL Оператор ExistsSQL Операторы Any, AllSQL SELECT INTOSQL INSERT INTO SELECTSQL Инструкция CASESQL Функции NULLSQL ХранимаяSQL Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Adblock
detector