что нужно исправить чтобы была нормальная дата?

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
virtuoz
Новичок
Новичок
 
Сообщения: 31
Зарегистрирован: 10.05.2006 (Ср) 15:36

что нужно исправить чтобы была нормальная дата?

Сообщение virtuoz » 21.05.2006 (Вс) 23:26

хочу сделать выборку по дате:
Код: Выделить всё
"SELECT * FROM Zapisi WHERE Datapriema>=" & _
    Text1 & " AND Datapriema<=" & Text2 & " order BY Nomer ASC"

вписываю дату в формате dd/mm/yyyy. а сравнение идет непонятно с чем, а чтобы работало нужно вводить дату в виде числа дней прошедших с 01.01.1900
например вместо 20/05/2006 и 21/05/2006 нужно вводить 38857 и 38858
почему так происходит и главное - как это исправить?

Хакер
Телепат
Телепат
Аватара пользователя
 
Сообщения: 16478
Зарегистрирован: 13.11.2005 (Вс) 2:43
Откуда: Казахстан, Петропавловск

Сообщение Хакер » 21.05.2006 (Вс) 23:52

Происходит это потому что так устроен мир :D

А исправить - ну а что тебе мешает переводить юзер-введённые данные в Text1/2 в datestamp формат, т.е. DateDiff'ом самому вычислять сколько прошло дней?
—We separate their smiling faces from the rest of their body, Captain.
—That's right! We decapitate them.

virtuoz
Новичок
Новичок
 
Сообщения: 31
Зарегистрирован: 10.05.2006 (Ср) 15:36

Сообщение virtuoz » 21.05.2006 (Вс) 23:55

А исправить - ну а что тебе мешает переводить юзер-введённые данные в Text1/2 в datestamp формат, т.е. DateDiff'ом самому вычислять сколько прошло дней?

мешает то что я не умею, можно поподробнее как это сделать

Хакер
Телепат
Телепат
Аватара пользователя
 
Сообщения: 16478
Зарегистрирован: 13.11.2005 (Вс) 2:43
Откуда: Казахстан, Петропавловск

Сообщение Хакер » 21.05.2006 (Вс) 23:58

Код: Выделить всё

daysraz=DateDiff("d", SomeTextBoxThatContentADate, DateSerial(1900,1,1))


В daysraz будет число дней прошедшее от даты в SomeTextBoxThatContentADate до даты отсчёта (01.01.1900)
—We separate their smiling faces from the rest of their body, Captain.
—That's right! We decapitate them.

vvs_adm
Гуру
Гуру
Аватара пользователя
 
Сообщения: 1492
Зарегистрирован: 03.02.2005 (Чт) 3:45
Откуда: оттуда ;)

Сообщение vvs_adm » 22.05.2006 (Пн) 0:05

To Хакер
Код: Выделить всё
MsgBox CLng(Date)

:wink:
Никогда не откладывай на завтра то, что можно ... отложить на послезавтра!

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 22.05.2006 (Пн) 0:10

vvs_adm, ты немного неправ. Надо еще 2 отнять.
Lasciate ogni speranza, voi ch'entrate.

Хакер
Телепат
Телепат
Аватара пользователя
 
Сообщения: 16478
Зарегистрирован: 13.11.2005 (Вс) 2:43
Откуда: Казахстан, Петропавловск

Сообщение Хакер » 22.05.2006 (Пн) 0:17

vvs_adm
Ну так как-то неэстетично...
—We separate their smiling faces from the rest of their body, Captain.
—That's right! We decapitate them.

vvs_adm
Гуру
Гуру
Аватара пользователя
 
Сообщения: 1492
Зарегистрирован: 03.02.2005 (Чт) 3:45
Откуда: оттуда ;)

Сообщение vvs_adm » 22.05.2006 (Пн) 0:24

alibek что-то я с ходу не найду, почему надо отнимать 2, а спать уже совсем сильно хочется :) может сам признаешься? :)
Никогда не откладывай на завтра то, что можно ... отложить на послезавтра!

vvs_adm
Гуру
Гуру
Аватара пользователя
 
Сообщения: 1492
Зарегистрирован: 03.02.2005 (Чт) 3:45
Откуда: оттуда ;)

Сообщение vvs_adm » 22.05.2006 (Пн) 0:27

Хакер писал(а):vvs_adm
Ну так как-то неэстетично...
Зато дешево, надежно и практично :lol:
Никогда не откладывай на завтра то, что можно ... отложить на послезавтра!

virtuoz
Новичок
Новичок
 
Сообщения: 31
Зарегистрирован: 10.05.2006 (Ср) 15:36

Сообщение virtuoz » 22.05.2006 (Пн) 0:28

2 отнимать похоже нужно вот в этом случае

Код: Выделить всё
daysraz=DateDiff("d", SomeTextBoxThatContentADate, DateSerial(1900,1,1))

virtuoz
Новичок
Новичок
 
Сообщения: 31
Зарегистрирован: 10.05.2006 (Ср) 15:36

Сообщение virtuoz » 22.05.2006 (Пн) 0:29

Хакер, большое спасибо за помощь

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 22.05.2006 (Пн) 8:09

vvs_adm писал(а):alibek что-то я с ходу не найду, почему надо отнимать 2, а спать уже совсем сильно хочется :) может сам признаешься? :)

Хм... Ну попробуй все-таки сам.
В крайнем случае сделай MsgBox Format$(CDate(0),"dd.mm.yyyy").
Lasciate ogni speranza, voi ch'entrate.

vvs_adm
Гуру
Гуру
Аватара пользователя
 
Сообщения: 1492
Зарегистрирован: 03.02.2005 (Чт) 3:45
Откуда: оттуда ;)

Сообщение vvs_adm » 22.05.2006 (Пн) 8:28

alibek
msgbox cstr(cdate(0))
msgbox cstr(cdate(1))
msgbox cstr(cdate(2))
:lol:
Вообще я имел в виду, что не нашел сразу описания, как хранится дата и т.д.
Никогда не откладывай на завтра то, что можно ... отложить на послезавтра!

Nicky
Постоялец
Постоялец
 
Сообщения: 519
Зарегистрирован: 12.08.2004 (Чт) 12:14

Сообщение Nicky » 22.05.2006 (Пн) 9:56

vvs_adm писал(а):To Хакер
Код: Выделить всё
MsgBox CLng(Date)

:wink:

CLng, вообще-то, округляет
Код: Выделить всё
Function SQLDate(d As Date, Optional bTime As Boolean) As String
  SQLDate = "#" & Format$(d, "mm\/dd\/yyyy" & IIf(bTime, " Hh:Nn:Ss", "")) & "#"
End Function


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 18

    TopList