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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 10.03.2009, 00:17
elfer elfer вне форума
Новичок
 
Регистрация: 06.02.2009
Сообщения: 63
Репутация: 10
По умолчанию Помогите с запросом

Есть таблица с полями date и times типа А. Как мне отобразить в другой таблице данные начиная с нужной даты и времени и до другой даты и времени. Мне нужен текст запроса. Заранее благодарен.
Ответить с цитированием
  #2  
Старый 10.03.2009, 13:56
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Ниче не понимаю... Одна таблица, другая... Что за другая таблица? Что значит "с нужной даты и до другой даты и времени"? Текст запроса SQL или чего? Тип полей DATE и TIMES A - это типа строковый? Может начать с правильного выбора типа полей?
Ответить с цитированием
  #3  
Старый 10.03.2009, 15:05
elfer elfer вне форума
Новичок
 
Регистрация: 06.02.2009
Сообщения: 63
Репутация: 10
По умолчанию

В поле дата соответственно дата, но строковый тип, в поле тайм - время. Я хочу сделать запрос: ввожу в едит дату в другой едит время (едит1 08.03.2009, едит2 08:00:00 по едит3 09.03.2009, едит4 08:00:00) и надо отобразить все данные в этом интервале
Ответить с цитированием
  #4  
Старый 10.03.2009, 15:43
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Если все таки для поля дата и время выбрать типы DateTime, то на SQL в QUERY это таk
Код:
SELECT 
  Поле_дата,
  Поле_время
FROM
 Имя_таблицы
WHERE
  (Поле_дата >= :edit_par_1) AND 
  (Поле_дата <= :edit_par_3) AND 
  (Поле_время >= :edit_par_2) AND 
  (Поле_время <= :edit_par_4)
:edit_par_1..4 в Query это параметры. Их значения делаем так
Код:
Query1.Parameters[0].value:=Edit1.Text; 
//где [0] индекс параметра, смотри св-во PARAMS в QUERY после того как SQL забъеш
Ответить с цитированием
  #5  
Старый 10.03.2009, 15:57
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

А еще есть BETWEEN, очень полезная в данном случае штука.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #6  
Старый 10.03.2009, 17:39
elfer elfer вне форума
Новичок
 
Регистрация: 06.02.2009
Сообщения: 63
Репутация: 10
По умолчанию

Спасибо помогли. :-)
А что за between? Можно подробнее и как с ним работать.
Ответить с цитированием
  #7  
Старый 10.03.2009, 17:56
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

BETEEN фактически заменяем 2 условия, реализующие попадание знаяения в некоторый диапазон.

Например, такой запрос:
Код:
SELECT * FROM MYTABLE WHERE DAY >=1 AND DAY <=15
через BETWEEN можно написать так:
Код:
SELECT * FROM MYTABLE WHERE DAY BETWEEN 1 AND 15
Ответить с цитированием
  #8  
Старый 10.03.2009, 18:09
elfer elfer вне форума
Новичок
 
Регистрация: 06.02.2009
Сообщения: 63
Репутация: 10
По умолчанию

У меня ошибка list index out of bounds (1)
Ответить с цитированием
  #9  
Старый 10.03.2009, 19:45
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

И? Где код, в котором ошибка?

Скорее всего сделал цикл с 1 до Count, а надо с 0 до Count-1.
Ответить с цитированием
  #10  
Старый 10.03.2009, 23:13
elfer elfer вне форума
Новичок
 
Регистрация: 06.02.2009
Сообщения: 63
Репутация: 10
По умолчанию

Цитата:
Сообщение от TOJluK
Если все таки для поля дата и время выбрать типы DateTime, то на SQL в QUERY это таk
Код:
SELECT 
  Поле_дата,
  Поле_время
FROM
 Имя_таблицы
WHERE
  (Поле_дата >= :edit_par_1) AND 
  (Поле_дата <= :edit_par_3) AND 
  (Поле_время >= :edit_par_2) AND 
  (Поле_время <= :edit_par_4)
:edit_par_1..4 в Query это параметры. Их значения делаем так
Код:
Query1.Parameters[0].value:=Edit1.Text; 
//где [0] индекс параметра, смотри св-во PARAMS в QUERY после того как SQL забъеш
Все работает, но небольшой косяк: например вводим дату с 10 числа по 12, все отображается, но если я ввожу время с 8.00 (10 числа) по 9.00 (12 числа) то выводятся данные 10, 11, 12 числа, но только в интервале с 8 до 9 часов каждого дня. Если по русски, то не отображаются например данные 10 числа, к примеру, в 11 часов
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter