Дата в формате дд мм гг как пишется
Содержание:
- SQL Учебник
- Oracle TO_DATE Format Mask
- Синтаксис
- Общие рекомендации
- Еще один взгляд на проблему «жизнь без последовательностей». Часть вторая (практическая) Промо
- Обобщенный синтаксис форматной строки
- Создание
- Описание типа данных datetimedatetime Description
- избежать LocalDateTime
- извне вашей системы
- о java.время
- Получение компонентов даты
- Преобразование даты в строку и её форматирование
- Использование функции Глобального контекста с примитивным типом данных Дата
- Структура DateTime
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 Комментарии
Oracle TO_DATE Format Mask
The Oracle TO_DATE function includes a “format mask”. The format mask is helpful as it allows you to specify what format the date value was provided in.
If, for example you have a charvalue of ’02/05/2017′, does this mean May 2nd or Feb 5th? The result of the Oracle TO_DATE function would depend on the format you specify, and may be obvious depending on what region you’re from.
To make it clear, we need to specify some values for the format mask as part of the Oracle TO_DATE function.
The possible values are:
Year
Parameter | Explanation |
YEAR | Year, spelled out in full words |
YYYY | 4-digit year |
YYY | Last 3 digits of year |
YY | Last 2 digits of year |
Y | Last digit of year |
IYY | Last 3 digits of ISO year |
IY | Last 2 digits of ISO year |
I | Last digit of ISO year |
IYYY | 4-digit year, which is based on the ISO standard |
RRRR | This format accepts a 2-digit year, and returns a 4-digit year. If the provided value is between 0 and 49, it will return a year greater than or equal to 2000. If the provided value is between 50 and 99, it will return a year less than 2000 |
Month
Parameter | Explanation |
Q | Quarter of year, from 1 to 4. JAN to MAR = 1 |
MM | Month, from 01 to 12. JAN = 01 |
MON | Abbreviated name of month. |
MONTH | Name of month, padded with blanks to length of 9 characters. |
RM | Roman numeral month, from I to XII. JAN = I. |
Week
Parameter | Explanation |
WW | Week of year, from 1 to 53. Week 1 starts on the first day of the year, and continues to the seventh day of the year. |
W | Week of month, from 1 to 5. Week 1 starts on the first day of the month and ends on the seventh. |
IW | Week of year, from 1 to 52 or 1 to 53, based on the ISO standard. |
Day
Parameter | Explanation |
D | Day of week, from 1 to 7. |
DAY | Name of day. |
DD | Day of month, from 1 to 31. |
DDD | Day of year, from 1 to 366. |
DY | Abbreviated name of day. |
J | Julian day, which is the number of days since January 1, 4712 BC. |
Time
Parameter | Explanation |
HH | Hour of day, from 1 to 12. |
HH12 | Hour of day, from 1 to 12. |
HH24 | Hour of day, from 0 to 23. |
MI | Minute, from 0 to 59 |
SS | Second, from 0 to 59 |
SSSSS | Seconds past midnight, from 0 to 86399. |
FF | Fractional seconds. This uses a value from 1 to 9 after FF, to indicate the number of digits in the fractional seconds (e.g. FF7) |
Indicators
Parameter | Explanation |
AM, A.M., PM, or P.M. | Meridian indicator |
AD or A.D | AD indicator |
BC or B.C. | BC indicator |
TZD | Daylight savings information |
TZH | Time zone hour. |
TZM | Time zone minute. |
TZR | Time zone region. |
As you can see, TO_DATE with time and date is possible, and it depends on the value being supplied.
Синтаксис
Синтаксис MySQL функции STR_TO_DATE:
STR_TO_DATE( string, format_mask )
Параметры или аргументы
string — строковое значение, которое нужно форматировать как дату.
format_mask — формат, применяемый к строке. Ниже приведен список параметров для параметра format_mask. Эти параметры могут использоваться во многих комбинациях.
Значение | Описание |
---|---|
%a | Сокращенное название дня недели (Sun до Sat) |
%b | Сокращенное название месяца (Jan до Dec) |
%c | Числовое значение месяца (0 до 12) |
%D | День месяца в виде числового значения, за которым следует суффикс (1st, 2nd, 3rd, …) |
%d | День месяца в виде числового значения (от 01 до 31) |
%e | День месяца в виде числового значения (от 0 до 31) |
%f | Микросекунды (от 000000 до 999999) %f доступны начиная с MySQL 4.1.1 |
%H | Час (от 00 до 23) |
%h | Час (от 00 до 12) |
%I | Час (от 00 до 12) |
%i | Минуты (от 00 до 59) |
%j | День года (001 — 366) |
%k | Час (от 00 до 23) |
%l | Час (от 1 до 12) |
%M | Название месяца полностью (January до December) |
%m | Название месяца в виде числового значения (от 00 до 12) |
%p | До или после полудня AM или PM |
%r | Время в 12-часовом формате AM или PM (hh:mm:ss AM/PM) |
%S | Секунды (от 00 до 59) |
%s | Секунды (от 00 до 59) |
%T | Время в 24-часовом формате (hh:mm:ss) |
%U | Неделя, где Sunday — первый день недели (от 00 до 53) |
%u | Неделя, где Monday — это первый день недели (от 00 до 53) |
%V | Неделя, где Sunday — первый день недели (от 01 до 53). Доступно начиная с версии MySQL 3.23.8 и используется с %X |
%v | Неделя, где Monday — первый день недели (от 01 до 53). Доступно начиная с версии MySQL 3.23.8 и используется с %X |
%W | Имя дня недели полностью (Sunday до Saturday) |
%w | День недели, где Sunday=0 and Saturday=6 |
%X | Год недели, где Sunday — первый день недели. Доступно начиная с версии MySQL 3.23.8 и используется с% V |
%x | Год недели, где Monday — первый день недели. Доступно начиная с MySQL 3.23.8 и используется с %v |
%Y | Год в виде числового значения из 4 цифр |
%y | Год в виде числового значения из 2 цифр |
Общие рекомендации
- Выделить интерфейс IDateTimeProvider с единственным методом, возвращающим текущее время. Затем добавить зависимость на этот интерфейс во всех единицах кода, где нужно получать текущее время. При обычном выполнении программы во все эти места будет инжектиться реализация «по умолчанию», которая возвращает реальное текущее время, а в юнит тестах – любая другая необходимая реализация. Такой способ является наиболее гибким с точки зрения тестирования.
- Сделать свой статический класс с методом для получения текущего времени и возможностью установить любую реализацию этого метода извне. Например, в случае C# кода этот класс может выставлять наружу свойство UtcNow и метод SetImplementation(Func<DateTime> impl). Использование статического свойства или метода для получения текущего времени избавляет от надобности везде явно прописывать зависимость от дополнительного интерфейса, но с точки зрения принципов ООП не является идеальным решением. Однако, если по каким-то соображениям предыдущий вариант не подходит, то можно воспользоваться этим.
клиенту доверять нельзяISO 8601
Еще один взгляд на проблему «жизнь без последовательностей». Часть вторая (практическая) Промо
В [1 — http://infostart.ru/public/62938/] был предложен метод корректировки списаний по партиям при изменении документов задним числом. Использование данного метода позволяет контролировать остатки при неоперативном проведении и поддерживать учет по партиям всегда в актуальном состоянии, то есть обходиться без механизма последовательности документов. Собственно метод заключался в решении задачи правильного списания по партиям как задачи линейного программирования.
В доказательство работоспособности метода приводится следующая «каркасная» конфигурация «Полигон», в которой этот метод реализован.
1 стартмани
Обобщенный синтаксис форматной строки
Форматная строка содержит обязательное описание типа данных и дополнительные параметры форматирования:
Тип
Имя параметра | Тип | Описание | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
# | Строка | Символ решетки используется для непосредственного форматирования значения во встроенных выражениях функций Шаблон() и ФиксШаблон(). | ||||||||||||
Тип* | Строка | Определяет тип форматируемого значения. Может принимать одно из следующих значений:
Если форматируемое значение имеет тип, отличный от типа, указанного в форматной строке, будет выполнено неявное преобразование типа согласно принятым правилам |
||||||||||||
Параметры | Строка | Дополнительные параметры форматирования. Состав параметров определяется выбранным типом | ||||||||||||
* — обязательный параметр |
Рассмотрим параметры для каждого типа подробнее…
Создание
Для создания нового объекта нужно вызвать конструктор с одним из следующих аргументов:
-
Без аргументов – создать объект с текущими датой и временем:
-
Создать объект с временем, равным количеству миллисекунд (тысячная доля секунды), прошедших с 1 января 1970 года UTC+0.
Целое число, представляющее собой количество миллисекунд, прошедших с начала 1970 года, называется таймстамп (англ. timestamp).
Это – легковесное численное представление даты. Из таймстампа всегда можно получить дату с помощью и преобразовать существующий объект в таймстамп, используя метод (см. ниже).
Датам до 1 января 1970 будут соответствовать отрицательные таймстампы, например:
-
Если аргумент всего один, и это строка, то из неё «прочитывается» дата. Алгоритм разбора – такой же, как в , который мы рассмотрим позже.
-
Создать объект с заданными компонентами в местном часовом поясе. Обязательны только первые два аргумента.
- должен состоять из четырёх цифр: значение корректно, – нет.
- начинается с (январь) по (декабрь).
- Параметр здесь представляет собой день месяца. Если параметр не задан, то принимается значение .
- Если параметры отсутствуют, их значением становится .
Например:
Максимальная точность – 1 мс (до 1/1000 секунды):
Описание типа данных datetimedatetime Description
Property (Свойство)Property | ЗначениеValue |
---|---|
СинтаксисSyntax | datetimedatetime |
ИспользованиеUsage | DECLARE @MyDatetime datetimeDECLARE @MyDatetime datetimeCREATE TABLE Таблица1 ( Столбец1 datetime )CREATE TABLE Table1 ( Column1 datetime ) |
Форматы строковых литералов по умолчаниюDefault string literal formats(используется для клиента нижнего уровня)(used for down-level client) | НеприменимоNot applicable |
Диапазон датыDate range | С я января 1753 года до 31 декабря 9999 годаJanuary 1, 1753, through December 31, 9999 |
Диапазон времениTime range | От 00:00:00 до 23:59:590,99700:00:00 through 23:59:59.997 |
Диапазон смещения часового поясаTime zone offset range | NoneNone |
Диапазоны элементовElement ranges | ГГГГ — четырехзначное число от 1753 до 9999, представляющее год.YYYY is four digits from 1753 through 9999 that represent a year.ММ обозначает 2 цифры, которые представляют месяц и принимают значения от 01 до 12.MM is two digits, ranging from 01 to 12, that represent a month in the specified year.Обозначение ДД состоит из двух цифр, представляющих день указанного месяца, и принимает значения от 01 до 31 в зависимости от месяца.DD is two digits, ranging from 01 to 31 depending on the month, that represent a day of the specified month.Обозначение чч состоит из двух цифр, представляющих час, и принимает значения от 00 до 23.hh is two digits, ranging from 00 to 23, that represent the hour.Обозначение мм состоит из двух цифр, представляющих минуту, и принимает значения от 00 до 59.mm is two digits, ranging from 00 to 59, that represent the minute.Обозначение сс состоит из двух цифр, представляющих секунду, и принимает значения от 00 до 59.ss is two digits, ranging from 00 to 59, that represent the second.Обозначение n* может содержать от нуля до трех цифр, представляющих доли секунды, и принимает значения от 0 до 999.n* is zero to three digits, ranging from 0 to 999, that represent the fractional seconds. |
Длина в символахCharacter length | Минимально 19 позиций, максимально — 2319 positions minimum to 23 maximum |
Объем памятиStorage size | 8 байт8 bytes |
ТочностьAccuracy | Округлено до приращения 0,000, 0,003 или 0,007 секундRounded to increments of .000, .003, or .007 seconds |
Значение по умолчаниюDefault value | 1900-01-01 00:00:001900-01-01 00:00:00 |
КалендарьCalendar | Григорианский (включает полный диапазон лет)Gregorian (Does include the complete range of years.) |
Определяемая пользователем точность в долях секундыUser-defined fractional second precision | НетNo |
Учет и сохранение смещения часового поясаTime zone offset aware and preservation | НетNo |
Учет перехода на летнее времяDaylight saving aware | НетNo |
избежать LocalDateTime
вопреки комментарию на вопрос Рамансба, вы должен!—67—>не использовать класс для текущей даты и времени.
на намеренно отсутствует какой-либо часовой пояс или смещение от UTC информации. Итак, это не уместно, когда вы отслеживаете определенный момент на временной шкале. Конечно не подходит для захвата текущего момента.
» локальная » формулировка противоречит интуиции. Это значит любой населенный пункт, а не любой специфическая местность. Например, Рождество в этом году начинается в полночь 25 декабря:, быть представленным как . Но это означает полночь в разных точках земного шара в разное время. Полночь случается первой в Кирибати, позже в Новой Зеландии, еще через несколько часов в Индии и так далее, и еще несколько часов до Рождества начинается во Франции, когда дети в Канаде все еще ждут этого дня. Каждый из этих рождественских стартовых пунктов будет представлен как отдельный .
извне вашей системы
если вы не можете доверять ваши часы, увидеть Java: получить текущую дату и время с сервера не системные часы и мой ответ:.
чтобы использовать альтернативного поставщика текущего момента, напишите подкласс абстрактного класса.
вы можете передать свой реализация в качестве аргумента для различных java.время методы. Например, .
для целей тестирования, обратите внимание на альтернативных реализаций доступные статически от : , , и многое другое
о java.время
на java.время framework встроен в Java 8 и более поздние версии. Эти классы вытесняют беспокойных старых наследие классы даты и времени, такие как , , & .
на Joda Времени, теперь режим обслуживания, советует переход к java.время классы.
чтобы узнать больше, см. Oracle Tutorial. И search Stack Overflow для многих примеров и объяснений. Спецификация JSR 310.
вы можете обменять java.время объекты непосредственно с вашей базой данных. Используйте драйвер JDBC соответствуют JDBC 4.2 или позже. Нет необходимости в строках, нет необходимости в занятия.
где получить java.время занятий?
-
, , и позже
- встроенный.
- часть стандартного API Java со встроенной реализацией.
- Java 9 добавляет некоторые незначительные функции и исправления.
-
и
-
Android
- более поздние версии Android bundle реализации java.классы время.
- для более раннего Android, ThreeTenABP проект приспосабливается ThreeTen-Backport (упоминалось выше). См.как использовать ThreeTenABP….
на ThreeTen-Extra проект расширяет java.время с дополнительными занятиями. Этот проект является испытательной площадкой для возможных будущих дополнений к java.время. Вы можете найти некоторые полезные классы, такие как , , и больше.
Получение компонентов даты
Существуют методы получения года, месяца и т.д. из объекта :
- getFullYear()
- Получить год (4 цифры)
- getMonth()
- Получить месяц, от 0 до 11.
- getDate()
- Получить день месяца, от 1 до 31, что несколько противоречит названию метода.
- getHours(), getMinutes(), getSeconds(), getMilliseconds()
- Получить, соответственно, часы, минуты, секунды или миллисекунды.
Никакого . Только
Многие интерпретаторы JavaScript реализуют нестандартный и устаревший метод , который порой возвращает год в виде двух цифр. Пожалуйста, обходите его стороной. Если нужно значение года, используйте .
Кроме того, можно получить определённый день недели:
- getDay()
- Вернуть день недели от (воскресенье) до (суббота). Несмотря на то, что в ряде стран за первый день недели принят понедельник, в JavaScript начало недели приходится на воскресенье.
Все вышеперечисленные методы возвращают значения в соответствии с местным часовым поясом.
Однако существуют и их UTC-варианты, возвращающие день, месяц, год для временной зоны UTC+0: getUTCFullYear(), getUTCMonth(), getUTCDay(). Для их использования требуется после подставить .
Если ваш местный часовой пояс смещён относительно UTC, то следующий код покажет разные часы:
Помимо вышеприведённых методов, существуют два особых метода без UTC-варианта:
- getTime()
-
Для заданной даты возвращает таймстамп – количество миллисекунд, прошедших с 1 января 1970 года UTC+0.
- getTimezoneOffset()
-
Возвращает разницу в минутах между местным часовым поясом и UTC:
Преобразование даты в строку и её форматирование
В JavaScript методы, выполняющие преобразование даты в строку, можно разделить на 2 группы.
К первой группе можно отнести методы, которые выполняют это так, как это определено в браузере: , , , .
Метод возвращает полное представление даты, – только дату, – только время, – полное представление даты, но в часовом поясе UTC+0.
Т.к. строковые представления, которые должны возвращать эти методы чётко не определены в стандарте, то они могут отличаться в разных браузерах.
Ко второй группе можно отнести методы с учётом часового пояса и языка локального компьютера: – дату и время, – только дату, – только время.
Методы , , имеют 2 необязательных параметра. Первый параметр предназначен для явного указания локали, второй — для задания опций форматирования.
Если локаль явно не установлена или , то браузер берёт ту, которую он имеет по умолчанию.
Кроме этого, в JavaScript имеется ещё метод . Он возвращает строку, содержащую дату и время в формате ISO ().
Пример:
// создадим дату 15.04.2019 18:43:59 (в часовом поясе пользователя) var newDate = new Date(2019, 03, 15, 18, 43, 59); console.log(newDate.toString()); // Mon Apr 15 2019 18:43:59 GMT+1000 (Владивосток, стандартное время) console.log(newDate.toDateString()); // Mon Apr 15 2019 console.log(newDate.toTimeString()); // 18:43:59 GMT+1000 (Владивосток, стандартное время) console.log(newDate.toLocaleString()); // 15.04.2019, 18:43:59 console.log(newDate.toLocaleDateString()); // 15.04.2019 console.log(newDate.toLocaleTimeString()); // 18:43:59 console.log(newDate.toUTCString()); // Mon, 15 Apr 2019 08:43:59 GMT console.log(newDate.toISOString()); // 2019-04-15T08:43:59.000Z
Использование функции Глобального контекста с примитивным типом данных Дата
Для примера возьмем функцию ДеньНедели, которая определяет номер дня недели для указанной даты, где 1 – понедельник, а 7 – воскресенье.
С помощью функции создадим обработку, определяющую, в какой день недели родился человек.
Создадим внешнюю обработку с двумя реквизитами:
- ДеньРождения типа Дата
- НазваниеДняНедели типа Строка
И перенесем реквизиты на форму.
Ранее мы задавали процедуры, связанные с командами, но запускать процедуру может не только кнопка. Процедура может запускаться при определенных условиях, например, при изменении реквизита. В данном случае сделаем так, чтобы после введения даты автоматически запускалась процедура расчета дня недели.
Для этого надо правой клавишей мышки щелкнуть по реквизиту ДатаРождения и в появившемся контекстном меню выбрать событие ПриИзменении:
Выберем создание обработчика события на клиенте.
Платформа 1С:Предприятие 8 автоматически ввела часть кода обработчика, связанную с условием запуска процедуры.
Чтобы получить день недели, код должен будет содержать следующие части:
- Массив данных, в котором будут храниться названия дней недели.
- Функцию ДеньНедели, которая вернет нам порядковый номер дня недели.
- Функцию, которая будет устанавливать соответствие между порядковым номером дня недели и элементом массива данных и выводить итоговые данные строкой.
Массив данных – это универсальная коллекция значений. Нумерация элементов массива начинается с 0 в квадратных скобках. Общее число элементов массива задается в круглых скобках. В массиве могут быть любые данные, в данном случае нам необходима Строка:
Массив=Новый Массив (7);
Массив=»понедельник»;
Массив=»вторник»;
Массив=»среда»;
Массив=»четверг»;
Массив=»пятница»;
Массив=»суббота»;
Массив=»воскресенье»;
Теперь нам с помощью функции ДеньНедели получить число, возвращаемое функцией от даты рождения.
Число=ДеньНедели(ДеньРождения);
Теперь из массива вытащим название дня недели, соответствующее реквизиту Число. При этом переменная Число может получать значения от 1(понедельник) до 7(воскресенье), поэтому для получения названия дня недели из массива уменьшим Число на 1 и присвоим полученное значение реквизиту формы НазваниеДняНедели.
Итоговый код обработчика будет выглядеть следующим образом:
Полный курс программиста 1С – с нуля до разработчика, способного решать практические учетные задачи в любой области.
Структура DateTime
Последнее обновление: 18.08.2016
Для работы с датами и временем в .NET предназначена структура DateTime. Она представляет дату и время от 00:00:00 1 января 0001 года
до 23:59:59 31 декабря 9999 года.
Для создания нового объекта DateTime также можно использовать конструктор. Пустой конструктор создает начальную дату:
DateTime date1 = new DateTime(); Console.WriteLine(date1); // 01.01.0001 0:00:00
То есть мы получим минимально возможное значение, которое также можно получить следующим образом:
Console.WriteLine(DateTime.MinValue);
Чтобы задать конкретную дату, нужно использовать один из конструкторов, принимающих параметры:
DateTime date1 = new DateTime(2015, 7, 20); // год - месяц - день Console.WriteLine(date1); // 20.07.2015 0:00:00
Установка времени:
DateTime date1 = new DateTime(2015, 7, 20, 18, 30, 25); // год - месяц - день - час - минута - секунда Console.WriteLine(date1); // 20.07.2015 18:30:25
Если необходимо получить текущую время и дату, то можно использовать ряд свойств DateTime:
Console.WriteLine(DateTime.Now); Console.WriteLine(DateTime.UtcNow); Console.WriteLine(DateTime.Today);
Консольный вывод:
20.07.2015 11:43:33 20.07.2015 8:43:33 20.07.2015 0:00:00
Свойство берет текущую дату и время компьютера, — дата и время относительно времени по
Гринвичу (GMT) и — только текущая дата.
При работе с датами надо учитывать, что по умолчанию для представления дат применяется григорианский календарь. Но что будет, если мы захотим получить день недели для
5 октября 1582 года:
DateTime someDate = new DateTime(1582, 10, 5); Console.WriteLine(someDate.DayOfWeek);
Консоль выстветит значение Tuesday, то есть вторник. Однако, как может быть известно из истории, впервые переход с юлианского календаря на григорианский
состоялся в октябре 1582 года. Тогда после даты 4 октября (четверг) (еще по юлианскому календарю) сразу перешли к 15 октября (пятница)(уже по григорианскому календарю).
Таким образом, фактически выкинули 10 дней. То есть после 4 октября шло 15 октября.
В большинстве случаев данный факт вряд ли как-то повлияет на вычисления, однако при работе с очень давними датами данный аспект следует учитывать.
Операции с DateTime
Основные операции со структурой DateTime связаны со сложением или вычитанием дат. Например, надо к некоторой дате прибавить или, наоборот,
отнять несколько дней.
Для добавления дат используется ряд методов:
-
: добавляет дату date
-
: добавляет к текущей дате несколько дней
-
: добавляет к текущей дате несколько часов
-
: добавляет к текущей дате несколько минут
-
: добавляет к текущей дате несколько месяцев
-
: добавляет к текущей дате несколько лет
Например, добавим к некоторой дате 3 часа:
DateTime date1 = new DateTime(2015, 7, 20, 18, 30, 25); // 20.07.2015 18:30:25 Console.WriteLine(date1.AddHours(3)); // 20.07.2015 21:30:25
Для вычитания дат используется метод Substract(DateTime date):
DateTime date1 = new DateTime(2015, 7, 20, 18, 30, 25); // 20.07.2015 18:30:25 DateTime date2 = new DateTime(2015, 7, 20, 15, 30, 25); // 20.07.2015 15:30:25 Console.WriteLine(date1.Subtract(date2)); // 03:00:00
Здесь даты различаются на три часа, поэтому результатом будет дата «03:00:00».
Метод Substract не имеет возможностей для отдельного вычитания дней, часов и так далее. Но это и не надо, так как мы можем передавать в метод
AddDays() и другие методы добавления отрицательные значения:
// вычтем три часа DateTime date1 = new DateTime(2015, 7, 20, 18, 30, 25); // 20.07.2015 18:30:25 Console.WriteLine(date1.AddHours(-3)); // 20.07.2015 15:30:25
Кроме операций сложения и вычитания еще есть ряд методов форматирования дат:
DateTime date1 = new DateTime(2015, 7, 20, 18, 30, 25); Console.WriteLine(date1.ToLocalTime()); // 20.07.2015 21:30:25 Console.WriteLine(date1.ToUniversalTime()); // 20.07.2015 15:30:25 Console.WriteLine(date1.ToLongDateString()); // 20 июля 2015 г. Console.WriteLine(date1.ToShortDateString()); // 20.07.2015 Console.WriteLine(date1.ToLongTimeString()); // 18:30:25 Console.WriteLine(date1.ToShortTimeString()); // 18:30
Метод преобразует время UTC в локальное время, добавляя смещение относительно времени по Гринвичу.
Метод , наоборот, преобразует локальное время во время UTC, то есть вычитает смещение относительно времени по Гринвичу.
Остальные методы преобразуют дату к определенному формату.
НазадВперед