Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.02.03;
Скачать: CL | DM;

Вниз

ПОмогите составить SQL запрос   Найти похожие ветки 

 
AntonUSAnoV   (2008-01-08 18:08) [0]

Такая проблема:
Есть БД по спортивным мероприятиям, в таблице отображаются соревнования, сроки проведения, для сроков в таблице Базы данных определены след. поля: число, месяц, год.
Нужно составить SQL запрос к БД типа: пользователь указывает диапазон времени формата с (число),(месяц) по (число)(месяц), и программа выдаёт все мероприятия, проходящие в эти сроки.

Изначально написал такой вот код, :
if c1 = "%" then
    query1.SQL[3]:="(chislo >= ""+c1+"" or chislo is null) and" else
    query1.SQL[3]:="(chislo >= ""+c1+"") and";
 if m1 = "%" then
    query1.SQL[4]:="(month1 like ""+m1+"" or month1 is null) and" else
    query1.SQL[4]:="(month1 like ""+m1+"") and";
 if c2 = "%" then
    query1.SQL[5]:="(chislo2 <= ""+c2+"" or chislo2 is null) and" else
    query1.SQL[5]:="(chislo2 <= ""+c2+"") and";
  if m2 = "%" then
    query1.SQL[6]:="(month2 like ""+m2+"" or month2 is null) and" else
    query1.SQL[6]:="(month2 like ""+m2+"") and";
  if vyear = "%" then
    query1.SQL[7]:="(year1 like ""+vyear+"" or year1 is null) and" else
    query1.SQL[7]:="(year1 like ""+vyear+"") and";


но он логически неверный, очень прошу помочь..


 
AntonUSAnoV   (2008-01-08 18:10) [1]

c1 -с какого числа производится поиск,
c2 - по какое число
m1 - с какого месяца
m2 - по какой месяц


 
Правильный_Вася   (2008-01-08 19:17) [2]

с 10 по 20 всех месяцев с февраля по май?
или с 10 февраля по 20 мая?


 
Malik   (2008-01-08 19:20) [3]

А не судьба  число, месяц, год в один тип сделать — Date сделать?


 
AntonUSAnoV   (2008-01-08 20:18) [4]


> Правильный_Вася  

с 10 февраля по 20 мая !


 
AntonUSAnoV   (2008-01-08 20:21) [5]


> Malik

Ну мероприятие длится с 10 мая по 20 мая , а формат даты если не ошибаюсь дд.мм.гггг, т.е. мне для правильной записи числа нужно будет записывать в формате с 10 мая 2007 по 20 мая 2007.


 
Malik   (2008-01-08 20:25) [6]


> AntonUSAnoV   (08.01.08 20:21) [5]

А что ты будеш делать с мероприятием который идет на стыке годов скажем 20 ноб 2007 по 20 фев 2008?


 
AntonUSAnoV   (2008-01-09 18:24) [7]


> Malik

Такого не бывает, нет год для обоих концов сроков не нужен.


 
Ega23 ©   (2008-01-09 18:30) [8]


> а формат даты если не ошибаюсь дд.мм.гггг,


Ошибаешься.
Читай про тип TDateTime и про его строковое представление.


 
Malik   (2008-01-09 18:48) [9]


> Читай про тип TDateTime и про его строковое представление.

Сори если правильно то так сделать: мм.дд.гггг???


 
Юрий Зотов ©   (2008-01-09 20:01) [10]

> AntonUSAnoV   (08.01.08 20:21) [5]

> а формат даты если не ошибаюсь дд.мм.гггг,

Это не формат даты, это формат ее строкового представления. И он может быть ЛЮБЫМ, каким Вы только захотите. А в таблице должно быть не 3 целых поля (день, месяц, год), а одно поле типа TDateTime (сразу вся дата). Тогда весь ваш запрос сразу станет очень простым (...where DATE between...) и гарантированно правильным (то есть, с автоматическим учетом високосных лет, разного количества дней в месяцах и всего остального).

> Malik   (09.01.08 18:48) [9]

Если правильно, то надо прочитать про тип TDateTime и понять, что в нем нет ни месяцев, ни годов. И что его строковое представление можно сделать ЛЮБЫМ. Хоть мм.дд.гггг, хоть как угодно иначе.



Страницы: 1 вся ветка

Текущий архив: 2008.02.03;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.041 c
3-1190717814
Nemec
2007-09-25 14:56
2008.02.03
InterBase


6-1172017429
Ш-К
2007-02-21 03:23
2008.02.03
Свои "контролы" в TWebBrowser.


15-1198605191
Maxim, P.
2007-12-25 20:53
2008.02.03
&amp; и ~ в cpp


15-1198599946
Kerk
2007-12-25 19:25
2008.02.03
Линуксоиды маст дай :)))


2-1199887795
Поручик
2008-01-09 17:09
2008.02.03
Получить писок файлов в папке.