Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 30.09.2013, 15:03
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию Отчет по датам

Народ. ай нид хэлп. база sql. Нужно сделать отчет из базы по дате. Начальная дата datetimepicker1, конечная datetimepicker2. Все понятно что нужно селектом фром и т.д. а вот что написать после where Date=...не знаю. подскажите пожалуйста
Ответить с цитированием
  #2  
Старый 30.09.2013, 15:09
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Код:
between

http://tigor.com.ua/blog/2008/08/23/...ator_of_mysql/
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #3  
Старый 30.09.2013, 15:09
Аватар для Uniq!
Uniq! Uniq! вне форума
Местный
 
Регистрация: 29.09.2010
Сообщения: 539
Версия Delphi: Delphi XE3
Репутация: 374
По умолчанию

Where Date >= StartDate AND Date <= EndDate
Ответить с цитированием
  #4  
Старый 30.09.2013, 15:15
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию

Цитата:
Сообщение от Uniq!
Where Date >= StartDate AND Date <= EndDate

а как StartDate присвоить значение Datetimepicker1?
Ответить с цитированием
  #5  
Старый 30.09.2013, 15:17
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Код:
datetimepickler.date
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #6  
Старый 30.09.2013, 15:21
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию

Цитата:
Сообщение от Mrak
Код:
datetimepickler.date

т.е. StartDate:=datetimepickler.date?

а как в Var объявить Startdate? каким типом?
Ответить с цитированием
  #7  
Старый 30.09.2013, 15:28
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Код:
Query.sql.text:='SELECT * FROM table WHERE date >= ' + datetostr(DateTimePickler1.date) + ' AND date <= ' + datetostr(DateTimePickler2.date);
Query.open;
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #8  
Старый 30.09.2013, 15:35
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию

Цитата:
Сообщение от Mrak
Код:
Query.sql.text:='SELECT * FROM table WHERE date >= ' + datetostr(DateTimePickler1.date) + ' AND date <= ' + datetostr(DateTimePickler2.date);
Query.open;


ругается на DateTimePickler1 пишет Undeclared Identifier
Ответить с цитированием
  #9  
Старый 30.09.2013, 15:39
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Жесть...
Не копируй тупо, там в названии ошибка, пиши DateTimePicker
По памяти писал, че-то думал там l после k
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #10  
Старый 30.09.2013, 15:46
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию

Цитата:
Сообщение от Mrak
Жесть...
Не копируй тупо, там в названии ошибка, пиши DateTimePicker
По памяти писал, че-то думал там l после k

пол дня уже с этим сижу, вот и не заметил...

теперь пишет что неправильный синтаксис около '2013'
Ответить с цитированием
  #11  
Старый 30.09.2013, 16:28
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Kis
пол дня уже с этим сижу, вот и не заметил...

теперь пишет что неправильный синтаксис около '2013'

Угу, дату надо конвертировать в строку и квотить. Но тут вылезут разные другие бяки, типа формата, разного на клиенте и сервере. Лучше передавай через параметры:
Код:
Query.sql.text:='SELECT * FROM table WHERE date between :startdate AND :enddate ';
Query.ParamByName('startdate').AsDateTime :=DateTimePickler1.date;
Query.ParamByName('enddate').AsDateTime :=DateTimePickler2.date;
Query.open;

Только посмотри, ParamByName может быть у Params, а не напрямую у Query...
Ответить с цитированием
  #12  
Старый 30.09.2013, 16:44
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию

Цитата:
Сообщение от lmikle
Угу, дату надо конвертировать в строку и квотить. Но тут вылезут разные другие бяки, типа формата, разного на клиенте и сервере. Лучше передавай через параметры:
Код:
Query.sql.text:='SELECT * FROM table WHERE date between :startdate AND :enddate ';
Query.ParamByName('startdate').AsDateTime :=DateTimePickler1.date;
Query.ParamByName('enddate').AsDateTime :=DateTimePickler2.date;
Query.open;

Только посмотри, ParamByName может быть у Params, а не напрямую у Query...

пытался так сделать...у меня после Query.ParamByName('startdate'). не дает выбрать AsDateTime. почему может быть?
Ответить с цитированием
  #13  
Старый 30.09.2013, 18:02
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Цитата:
Сообщение от lmikle
Угу, дату надо конвертировать в строку и квотить. Но тут вылезут разные другие бяки, типа формата, разного на клиенте и сервере.

ну можно и не квотить, если про quotedtostr, т.к. циферки и даты мускл хавает без кавычек (только не надо так в веб-программировании делать, там лучше все в кавычки)))
формат дат можно привести к одному с помощью функции formatdatetime...

но параметрами, конечно же, лучше (наверное )
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #14  
Старый 01.10.2013, 06:13
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Вот код для разных технологий доступа к БД (Delphi7):
Код:
  // BDE
  Query1.ParamByName('param_name').AsDateTime := DateTimePicker1.Date;

  // ADO
  ADOQuery1.Parameters.ParamByName('param_name').Value := DateTimePicker1.Date;

  // IBX
  IBQuery1.ParamByName('param_name').AsDateTime := DateTimePicker1.Date;

  // dbExpress
  SQLQuery1.ParamByName('param_name').AsDateTime := DateTimePicker1.Date;

Могу еще посмотреть в XE3. Но там, вроде, ничего нового нет, а FireDAC у меня нет. В ODAC (для Оракла), если мне память не изменяет, так же, как и в BDE.
Ответить с цитированием
  #15  
Старый 01.10.2013, 09:32
Kis Kis вне форума
Новичок
 
Регистрация: 02.09.2011
Сообщения: 76
Репутация: 11
По умолчанию

Спасибо, помогло!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 10:09.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter