С Новым годом! Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33

Параметризированный запрос

07.09.2016, 09:30. Показов 1938. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здесь уже обсуждались подобные вопросы, но у меня странная, на мой взгляд, ситуация. Делаю Параметризированный запрос для отбора по дате/времени такого вида:
Delphi
1
2
3
4
5
6
7
8
9
10
  with unit2.DataModule2.ADOQuery1 do begin
         Close;
         SQL.Clear;
         SQL.Add('SELECT * FROM tabl');
         SQL.Add('WHERE h5<>'+quotedstr(XXX));
  If  CheckBox1.Checked Then
      begin
         SQL.Add('And date >= :dateFrom');
         Parameters.ParamByName('dateFrom').Value := DateTimeEh1.Value;
      end;
При обращении к MS SQL все работает на ура. А с My SQL работать отказывается на отрез. Сообщение об ошибке "Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт друг с другом". Пробовал добавлять кавычки одиночные и двойные, задавать параметр прямо в свойствах запроса, изменял разделители формата даты и формат в общем. Одно и то же. Буду признателен за совет.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.09.2016, 09:30
Ответы с готовыми решениями:

Параметризированный SQL запрос
Доброго времени суток всем. Не могу сообразить почему это работает... procedure...

Параметризированный запрос к базе черех dataset
Добрый день! ПРоблема следующая. Делаю параметризованный зхапрос к базе во так MainUnit.MainForm.IBDataSetValues.Transaction :=...

Параметризированный запрос
Доброго времени суток, имеется БД формата mdb, подключенная к DataGridView, нужно создать запрос на выборку. Например. В таблице данные о...

8
7 / 7 / 2
Регистрация: 21.07.2016
Сообщений: 68
07.09.2016, 10:30
Проверьте запрос в каком нибудь менеджере для MySQL, возможно сам запрос неправилен
0
12 / 10 / 7
Регистрация: 08.02.2013
Сообщений: 254
07.09.2016, 10:43
Delphi
1
Parameters.ParamByName('dateFrom').Value := DateTimeEh1.Value;
На сколько я помню, Value не понимает значение типа DataTime. Отсюда и конфликт. Укажи конкретно тип если это Дата.
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
07.09.2016, 10:49  [ТС]
В том то и дело, что проверял. В MySQL-Front и непосредственно в string ADOQuery, работает зараза. Только там прямой запрос, без параметритизации. Подозреваю, что дело в этом.
А не может быть проблема в том, что в первом случае я беру данные из одной таблицы, а во втором из трех?

Добавлено через 3 минуты
Пробовал. AsDateTime, AsString. Не принимает. В DateTimePicker от Ehlib эти аргументы не канают.
0
7 / 7 / 2
Регистрация: 21.07.2016
Сообщений: 68
07.09.2016, 10:52
Поставь точку останова после
Delphi
1
Parameters.ParamByName('dateFrom').Value := DateTimeEh1.Value;
скопируй текст и посмотри что получается
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
15.09.2016, 11:03  [ТС]
Некоторое время не занимался этим вопросом, но он не решился, сволочь. Перерыл кучу информации, такая проблема возникает не только при запросе даты, а любых других значений. Вычитал, что в MySQL параметризированные запросы не работают без PREPARE STATEMEN, т. е. без подготовки запроса. Я с этой хренью никогда не сталкивался, может кто подскажет что к чему, или где поискать?
0
5953 / 4529 / 1094
Регистрация: 29.08.2013
Сообщений: 28,121
Записей в блоге: 3
15.09.2016, 13:35
Delphi
1
query.prepare;
не подойдет?
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
17.09.2016, 20:53
Не нравится мне в вашем запросе поле с именем date, попробуйте его написать так [date] или так "date". Вообще в классическом MySQL все имена полей и таблиц должны быть взяты в кавычки, т.е. примерно так:
Delphi
1
2
3
4
5
6
7
8
9
10
with unit2.DataModule2.ADOQuery1 do begin
         Close;
         SQL.Clear;
         SQL.Add('SELECT ''tabl''.* FROM ''tabl''');
         SQL.Add('WHERE ''tabl''.''h5''<>'+quotedstr(XXX));
  If  CheckBox1.Checked Then
      begin
         SQL.Add('And ''tabl''.''date'' >= :dateFrom');
         Parameters.ParamByName('dateFrom').Value := DateTimeEh1.Value;
      end;
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
18.09.2016, 13:35  [ТС]
НЕ знаю. Запрос у меня динамический по многим полям, все работает без кавычек. Правда там обычные, не параметризованные переменные. Дату делаю так, дабы избежать проблем с разными региональными настройками.
P.S. Сейчас пока в отпуске и не занимаюсь этим. Выйду на работу буду дерзать. А пока всем спасибо. Проверю все варианты.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.09.2016, 13:35
Помогаю со студенческими работами здесь

Параметризированный запрос.
В Access создаю один запрос с одним параметром. В модуле инициализирую этот параметр след. образом: db.QueryDefs(0).Parameters(0) =...

MSSQL. Параметризированный запрос
Привет ! Есть следующая конструкция: select * from blablabla where blabalba IN ('x1','x2'); нужно передавать список который в...

Параметризированный запрос sql
Подскажите пожалуйста, как добавить параметризированный запрос в код, чтобы условие считывалось из textBox. private DataTable...

ADO и параметризированный запрос
Скажите, а как использовать ADODC компонент, чтобы получить adodc.recordset, используя параметризированный запрос?

Параметризированный запрос на языке SQL
поддерживает ли mssql параметризированный запрос формата SELECT * FROM TableName WHERE ColumnName IN(@vals) и какой тип параметра будет...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru