Поиск:

Ответ в темуСоздание новой темы Создание опроса
> TDateTime, записать время 
:(
    Опции темы
Лена
Дата 30.10.2006, 10:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 879
Регистрация: 16.8.2006

Репутация: 11
Всего: 11



Так получаю текущее время:
Код

TDateTime tpar = Time();
    WORD Hour, Min, Sec, MSec;
    DecodeTime(tpar, Hour, Min, Sec, MSec); 
TDateTime tpar2;

Как записать в tpar2 ровно 12 часов ночи?

PM MAIL   Вверх
Link90
Дата 30.10.2006, 10:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


"Битый" пиксель
*


Профиль
Группа: Участник
Сообщений: 214
Регистрация: 25.11.2005
Где: Иркутск - середин а земли!

Репутация: 3
Всего: 7



Системную дату и время можно получать командой FormatDateTime("hh:mm:ss",Now());, при этом можно указать формат даты/времени. Может тебе это поможет...

Цитата

ровно 12 часов ночи

у тебя tpar2 имеет тип TDateTime, и записать в него строковое значение никак не получится...
PM MAIL ICQ   Вверх
Fazil6
Дата 30.10.2006, 10:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1653
Регистрация: 3.5.2006
Где: Минск

Репутация: 11
Всего: 60



Цитата

у тебя tpar2 имеет тип TDateTime, и записать в него строковое значение никак не получится...

неправда. Запросто строку можно присваивать.

Код

TDateTime dt = String("01.01.2006 00:00:00");

PM MAIL   Вверх
Лена
Дата 30.10.2006, 11:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 879
Регистрация: 16.8.2006

Репутация: 11
Всего: 11



Мне для SQL запроса надо динамически получить два параметра для between где диапазон должен быть от начала текущих суток до текущего момента времени. Скажите а так правильно?:
Код

   TDateTime tpar = Time();  //текущее время
    
    TDateTime tpar2 = 0; //начало суток


Это сообщение отредактировал(а) Лена - 30.10.2006, 11:09
PM MAIL   Вверх
Vyacheslav
Дата 30.10.2006, 11:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 2124
Регистрация: 25.3.2002
Где: Москва

Репутация: 47
Всего: 59



12 часов ночи это 00:00.
Если я не ошибаюсь, то просто 
Код

TDateTime tpar = 0;


Если же требуется записать 00:00  текущего дня, то
Код

TDateTime tpar = Now();
TDateTime tpar2 = int(tpar); 


Если же требуется записать 00:00  слежующего  для, то
Код

TDateTime tpar = Now();
TDateTime tpar2 = int(tpar) + 1; 







--------------------
С уважением, Вячеслав Ермолаев
PM MAIL WWW ICQ   Вверх
Лена
Дата 30.10.2006, 11:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 879
Регистрация: 16.8.2006

Репутация: 11
Всего: 11



Спасибо.

Я тут еще придумала код. Посмотрите он правильный?  smile 
В базе данных в колонке времени храняться такие записи типа "2006-10-30 11:25:10.29". Милисекунды отделены точкой (база PostgreSQL).
Код

    TDateTime tpar = Time();
    WORD Hour, Min, Sec, MSec;
    DecodeTime(tpar, Hour, Min, Sec, MSec); //текущее время
    tpar = Date();
    WORD Day, Month, Year;
    DecodeDate(tpar,Year, Month,Day); //текущая дата

    //формируем первый параметр:
    String ch = IntToStr(Year)+"-"+IntToStr(Month)+"-"+IntToStr(Day) +" "+ IntToStr(Hour)+":"+IntToStr(Min)+":"+IntToStr(Sec)+"."+ IntToStr(MSec);

    //формируем второй параметр:
    String ch1 = IntToStr(Year)+"-"+IntToStr(Month)+"-"+IntToStr(Day) + " " + "00:00:00.00";

Если я буду в SQL запрос передовать ch и ch1 это сработает?

Это сообщение отредактировал(а) Лена - 30.10.2006, 11:31
PM MAIL   Вверх
Snowy
Дата 30.10.2006, 11:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Модератор
Сообщений: 11363
Регистрация: 13.10.2004
Где: Питер

Репутация: 1
Всего: 484



Midnight = Trunc(now);  smile
PM MAIL   Вверх
pandrew
Дата 30.10.2006, 11:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 213
Регистрация: 27.3.2006

Репутация: 3
Всего: 3



Посмотрела бы в хелпе - увидела бы:
TDateTime()
When called with no arguments, the resulting TDateTime object has a Val data member of zero. This date and time corresponds to 12/30/1899 12:00 am.
Т.о. твой код приведет тебя в 19-й век.
Тебе правильно написали сейчас - это ::Now() или TDateTime:: CurrentDateTime(). 
Ну и далее можешь использовать DecodeTime и DecodeDate.

Код типа TDateTime tpar = 0; или (int)date - работает, но есть типичное жульничество.

Формат даты в SQL предложениях зависит от типа СУБД (увы!), хотя есть и универсальный вариант, но по этому поводу советов на форумах полно - ищи, не хочу повторяться.
PM MAIL   Вверх
Лена
Дата 30.10.2006, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 879
Регистрация: 16.8.2006

Репутация: 11
Всего: 11



Цитата(pandrew @  30.10.2006,  11:48 Найти цитируемый пост)
Т.о. твой код приведет тебя в 19-й век.


Проверила, все нормально.
SQL запрос составленный на основе моего последнего сообщения (где формирую ch и ch1) работает - делает выборки. Причем точка перед милесекундами обязательна.


PM MAIL   Вверх
Rodman
Дата 30.10.2006, 13:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 7
Всего: 122



Код

TDateTime dt = String("01.01.2006 00:00:00");


или можно попробовать использовать функции
Код

minutesbetween(...);
secondsbetween(...);


а затем прибавить или отнять (от текущего) - смотря какие 12 часов ночи тебе необходимо... будущие или прошлые

Это сообщение отредактировал(а) Rodman - 30.10.2006, 13:05
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Vyacheslav
Дата 30.10.2006, 15:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 2124
Регистрация: 25.3.2002
Где: Москва

Репутация: 47
Всего: 59



Цитата(Лена @  30.10.2006,  11:30 Найти цитируемый пост)
Если я буду в SQL запрос передовать ch и ch1 это сработает?

Что, Вас все на усложнение тянет. Зачем лишние переводы и формирование запроса посредством набора текста.
Используйте параметрические запросы и в параметры просто подставляйте прямо TDateTime



--------------------
С уважением, Вячеслав Ермолаев
PM MAIL WWW ICQ   Вверх
Лена
Дата 30.10.2006, 16:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 879
Регистрация: 16.8.2006

Репутация: 11
Всего: 11



Цитата(Vyacheslav @  30.10.2006,  15:51 Найти цитируемый пост)
Используйте параметрические запросы и в параметры просто подставляйте прямо TDateTime


Тут, я так понимаю, речь идет о параметрах в Builder в спец. свойстве инспектора объектов? Я сейчас пишу не в Builder а на специализированном C++ Script, усеченного компилятора. Тут нет таких широких возможностей. 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++ Builder"
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по С++ Builder обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Настоятельно рекомендуем заглянуть в DRKB (Delphi Russian Knowledge Base) - крупнейший в рунете сборник материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Rrader.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C++ Builder | Следующая тема »


 




[ Время генерации скрипта: 0.0847 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.