|
#1
|
|||
|
|||
SQL запрос
Всем добра! Подскажите пожалуйста, что в моем запросе не так
Код:
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 |
#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
|
||||
|
||||
Потому и говорю, что стремно, а так бы сказал что неправильно. Но дело даже не в этом. Чистой даты , как таковой нет. Есть Дата и Время, где время как-бы скрыто. И при таком раскладе вполне возможна ситуация, когда у двух сравниваемых переменных Даты будут одинаковы, а вот время может слегка расходится. Для периода это не страшно, а вот тут сравнение уже не прокатит.
Жизнь такова какова она есть и больше никакова. Помогаю за спасибо. |