![]() |
|
|
#1
|
|||
|
|||
|
Всем добра! Подскажите пожалуйста, что в моем запросе не так
Код:
procedure Tvidbilprodform.DateTimePicker1Change(Sender: TObject);
begin
adoquery1.SQL.Clear;
adoquery1.SQL.Add('select * from m6 where tabn=:tabn and datap=:dat2 or datap=:dat');
adoquery1.Parameters.ParamByName('dat').Value:=datetostr(datetimepicker1.Date);
adoquery1.Parameters.ParamByName('dat2').Value:=datetostr(datetimepicker1.Date+1);
adoquery1.Parameters.ParamByName('tabn').Value:=label2.Caption;;
adoquery1.Active:=true;
end;Требуется чтобы выводил данные на опр. tabn номер за два дня. Другими словами в таблице данные которые забил человек (tabn) за свою смену (смена с 20:00 до 8:00, поэтому за два дня). данные в базе. по одной записи в день. 29.05.2014 1111(tabn) 30.05.2014 2222 при выборе 30 числа и tabn 1111 выдает запись 30.05.2014 2222. при выборе 29 выдает 29.05.2014 1111 |
|
#2
|
||||
|
||||
|
Присваивать значение параметра даты через DateToStr -- за гранью добра и зла.
|
|
#3
|
|||
|
|||
|
ну я тот еще "чокнутый профессор"
а по теме, проблема вроде решена adoquery1.SQL.Add('select * from m6 where tabn=:tabn and (datap=:dat or datap=:dat2)'); сейчас данных добавлю и проверю чтобы убедиться |
|
#4
|
||||
|
||||
|
Цитата:
Код:
adoquery1.SQL.Add('select * from m6 where tabn=tabn and (datap=dat or datap=dat2)'); |
|
#5
|
||||
|
||||
|
Код:
(datap=dat or datap=dat2) Код:
(datap between :dat and :dat2) |
|
#6
|
|||
|
|||
|
Алеган, с двоеточием - это параметр.
Страдалец, у него по определению последовательно идущие даты. ТС, а зачем вообще вводить вторую дату. Можно просто вводить только первую, а вторую рассчитывать. Тогда будет всего одна запись на человека-смену, что сильно облегчит логику... |
|
#7
|
||||
|
||||
|
Потому и говорю, что стремно, а так бы сказал что неправильно. Но дело даже не в этом. Чистой даты , как таковой нет. Есть Дата и Время, где время как-бы скрыто. И при таком раскладе вполне возможна ситуация, когда у двух сравниваемых переменных Даты будут одинаковы, а вот время может слегка расходится. Для периода это не страшно, а вот тут сравнение уже не прокатит.
|