Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.01.24;
Скачать: [xml.tar.bz2];




Вниз

Как в MSSQL через INSERT вставить поле DATE 


kserg@ukr.net   (2001-12-14 12:12) [0]

Привет. В таблице есть поле типа DateTime.
При попытке вставки новой записи через INSERT...,
где дату представляю как строку вылетает ошибка
(а в Interbase такой финт проходил)

quTemp1.SQL.Add("INSERT INTO Test (data1) VALUES ("
+#39+ DateToStr(Date)+#39+")");



Догадываюсь, что надо значение конвертнуть.
Подскажите,как правильно это сделать.
Заранее благодарен.



Mick   (2001-12-14 12:14) [1]

И что вы все так не любите параметрические запросы?



SQLMan   (2001-12-14 12:49) [2]

Все дело в формате. Я поступаю следующим образом:

...INSERT INTO ... VALUES (GetDate());

Текущую дату и время MS SQL таким образом проглатывает.

Удачи.



kserg@ukr.net   (2001-12-14 12:55) [3]

>SQLMan - идея понятна и ваш вар-т для вставки новой записи вполне пойдет,
а как быть когда надо изменить дату через UPDATE ?
Ведь суть проблемы остается.



Mick   (2001-12-14 12:59) [4]

А если клиент хочет вставить свою системную дату, а
сервер стоит в другом часовом поясе?



Tonie   (2001-12-14 13:07) [5]

По моему Mick (14.12.01 12:14) прав
..Sql = "INSERT INTO Test (data1) VALUES (:MyDate)"
параметр должен быть DateTime
потом ..ParamByName("MyDate").AsDateTime := MyDate



SQLMan   (2001-12-14 13:16) [6]

>Mick- А зачем так заморачиваться? Ведь время и дата сервера имеют больший приоритет. А в случае UPDATE дату и время придется конвертировать через DateTimeToStr. А лучше всего использовать параметр! Это будет и проще и надежнее.



Tonie   (2001-12-14 13:33) [7]

Если эта дата на уровне сервера известна так лучше ее вообще триггером вставлять



Mick   (2001-12-14 13:54) [8]

SQLMan: Клиент например хочет вставить астрономическое время сделки (местное) и чей-то приоритет его не волнует.

А про то как "проще и надежнее" человеку был сразу дан ответ.



kserg@ukr.net   (2001-12-14 14:22) [9]

Благодарю всех за содействие.
Не услышав нужного ответа (дискуссия пошла в напр-нии "ЧТО лучше", хотя меня интересовало, что дает ошибку),
всё же пришлось самому "копать" глубже и оказалось, что ошибка при вставке возникала из-за разных форматов представления даты: в БД мм.дд.гг , а я упорно пытался воткнуть дд.мм.гг .
Вот уж наверное ГРАБЛИ, котр. многие прошли...

Т.е. вставить дату через SQL-insert можно используя функцию CAST() или просто представляя дату как строку, только в КОРРЕКТНОМ формате.



Tonie   (2001-12-14 14:29) [10]

При использовании параметров этих "граблей" нет, но если непременно желается так писать, то тогда действительно CAST или CONVERT



Delirium   (2001-12-14 16:03) [11]

MSSQL опримально работает с форматом yyyymmdd, т.е.
"10 января 2001" = "20010110"



SQLMan   (2001-12-14 17:11) [12]

Господа программеры! Автор прав. Все зависит от того, в каком формате представляется дата в SQL Server. Можно писать и через "December 14, 2001" или "20011214", причем как обычную строку:
... WHERE Date1="20011214"



Delirium   (2001-12-14 17:15) [13]

>SQLMan
Формат yyyymmdd - универсальный и ни от чего не зависит, по крайней мере в
MSSQL 6.5-2000



SQLMan   (2001-12-14 17:27) [14]

>Delirium
Правда, не учтя особенности этого формата, можно пытаться записать дату в формате, отличном от принятого в SQL Server по умолчанию. Насколько мне известно, формат даты зависит от региональных установок. Не так ли?



Delirium   (2001-12-14 18:13) [15]

>SQLMan
Не надо спорить, проверь если не веришь, формат yyyyddmm не зависит ни от каких региональных и иных установок в MSSQL.



Delirium   (2001-12-14 18:17) [16]

Ошиблся yyyymmdd , конечно :)
Он существует наравне с принятыми региональными форматами.



kserg@ukr.net   (2001-12-19 13:22) [17]

Раз пошла такая песня - ещё вопросик.
А где в MSSQL можно настроить формат даты?
Что то я с ходу и не нашел...
(я понял, что с региональными установками MSSQL плохо дружит)



Delirium   (2001-12-19 13:29) [18]

Читай хелп по SET DATEFORMAT




Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.01.24;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.74 MB
Время: 0.047 c
6-75632           KarlovAF              2001-11-01 16:55  2002.01.24  
Маска подсети.


3-75469           Buben                 2001-12-19 09:48  2002.01.24  
RDM + IBEvents


4-75710           manumba               2001-09-24 21:50  2002.01.24  
SetWindowsHookEx (WH_Keyboard....) - срабатывает два раза(вместо одного)....


6-75635           Dmitry V. Averuanov   2001-11-02 15:42  2002.01.24  
Мучительный вопрос:


1-75614           Vitalik               2002-01-06 21:08  2002.01.24  
создание динамических массиво в Pascale