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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.02.2007, 20:34
Washington Washington вне форума
Прохожий
 
Регистрация: 14.02.2007
Сообщения: 29
Репутация: 10
По умолчанию ADOQuery и Ini-файлы

Вопрос по параметрам!
Код:
Ini:=TIniFile.Create(IniFileName);
Sis:=Ini.ReadInteger('User','Sis',0);
with Form1.ADOQuery1 do
begin
  SQL.Clear;
  SQL.Add('Select Reports');
  SQL.Add('From Reports');
  SQL.Add('Where Sis<=:Sis');
  Parameters[0].Value:=Sis;
  Active:=True;
  open;
end;
Ошибка:
Цитата:
Отсутствует значение для одного или нескольких параметров.
Всё перепроверил - ничего не получается. Чо делать?
__________________
Ну это нормально...
Ответить с цитированием
  #2  
Старый 15.02.2007, 05:36
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Попробуй так:
Код:
Ini:=TIniFile.Create(IniFileName);
Sis:=Ini.ReadInteger('User','Sis',0);
with Form1.ADOQuery1 do
begin
  SQL.Clear;
  SQL.Add('Select Reports');
  SQL.Add('From Reports');
  SQL.Add('Where Sis<=:Sis');
  Parameters.ParseSQL(SQL.Text,True);
  Parameters.ParamByName('Sis').Value:=Sis;
//  Active:=True;  - Это лишнее
  open;
end;
Ответить с цитированием
  #3  
Старый 15.02.2007, 08:44
dron-s dron-s вне форума
Прохожий
 
Регистрация: 08.02.2007
Сообщения: 44
Репутация: 10
По умолчанию

попробуй так
Код:
with Form1.ADOQuery1 do
begin
  SQL.Clear;
  SQL.Add('Select Reports');
  SQL.Add('From Reports');
  SQL.Add('Where Sis<=:Sis');

  Ini:=TIniFile.Create(IniFileName);
  ParamByName('Sis').AsInteger := StrToInt(Ini.ReadInteger('User','Sis',0));

 Active:=True;
end;
я как понял, что sis у тебя имеет численный тип...
а параметр можешь передавать и без всяких переменных...
Ответить с цитированием
  #4  
Старый 15.02.2007, 08:54
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Неправда Ваша, dron-s.
Нету у TParameter свойства AsInteger да и прочих As... тоже.
Так же нет у TADOQuery метода ParamByName. Приведенный Вами код вообще компилироваться не будет.
Я тут описался как-то раз про As..., посыпаю голову пеплом, но если Вы не проверяли, то зачем советуете?
Ответить с цитированием
  #5  
Старый 15.02.2007, 09:14
dron-s dron-s вне форума
Прохожий
 
Регистрация: 08.02.2007
Сообщения: 44
Репутация: 10
По умолчанию

да. и правда as нет, но есть Value
так что перепишу вот так
Код:
with Form1.ADOQuery1 do
begin
  SQL.Clear;
  SQL.Add('Select Reports');
  SQL.Add('From Reports');
  SQL.Add('Where Sis<=:Sis');

  Ini:=TIniFile.Create(IniFileName);
  Parameters.ParamByName('Sis').Value := StrToInt(Ini.ReadInteger('User','Sis',0));

 Active:=True;
end;
Ответить с цитированием
  #6  
Старый 15.02.2007, 11:36
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

И опять не будет компилироваться
Ответить с цитированием
  #7  
Старый 15.02.2007, 13:48
dron-s dron-s вне форума
Прохожий
 
Регистрация: 08.02.2007
Сообщения: 44
Репутация: 10
По умолчанию

и в чём же ошибка на этот раз?
p.s. просто нет delphi под руками чтобы проверить...
Ответить с цитированием
  #8  
Старый 15.02.2007, 16:09
Washington Washington вне форума
Прохожий
 
Регистрация: 14.02.2007
Сообщения: 29
Репутация: 10
По умолчанию

А ошибка в этот раз в том, что ParamByName только у обычного Query есть. У ADO его нету. У ADO только Parameters[] есть. По индексу.
__________________
Ну это нормально...
Ответить с цитированием
  #9  
Старый 16.02.2007, 05:50
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

2 Washington
Как это нету, все есть.
Кстати, у обычного TQuery.Params.ParamByName
у TADOQuery.Parameters.ParamByName
2 dron-s
StrToInt(Ini.ReadInteger('User','Sis',0)) - ошибка, несоответствие типов.
TIniFile.ReadInteger - тип LongInt
Ответить с цитированием
  #10  
Старый 16.02.2007, 08:04
dron-s dron-s вне форума
Прохожий
 
Регистрация: 08.02.2007
Сообщения: 44
Репутация: 10
По умолчанию

Хех, ну уберите StrToInt и всё будет нормально...
просто я то думал что он в конце концов получает строку...
p.s. для автора наглядный пример порпробывать и разобраться самому, а не скатывать всё готовое с форума и говорить что я это сам сделал... пусть будет хоть доля правды
Ответить с цитированием
  #11  
Старый 16.02.2007, 11:07
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Не буду вдаваться во флейм, скажу только что сам виноват, не посмотрел раздел, думал что Начинающим
Ответить с цитированием
  #12  
Старый 16.02.2007, 13:35
Washington Washington вне форума
Прохожий
 
Регистрация: 14.02.2007
Сообщения: 29
Репутация: 10
По умолчанию

Дак сделал, как вы посоветовали. Всё равно ошибка. С форума я ничего не скатываю, а просто прошу помощи в решении проблемы. И всё.
__________________
Ну это нормально...
Ответить с цитированием
  #13  
Старый 16.02.2007, 20:47
dron-s dron-s вне форума
Прохожий
 
Регистрация: 08.02.2007
Сообщения: 44
Репутация: 10
По умолчанию

какая ошибка на этот раз?
p.s.телепаты в отпуске...
Ответить с цитированием
  #14  
Старый 17.02.2007, 16:03
Washington Washington вне форума
Прохожий
 
Регистрация: 14.02.2007
Сообщения: 29
Репутация: 10
По умолчанию

Та же самая ошибка. В начале описал.
__________________
Ну это нормально...
Ответить с цитированием
  #15  
Старый 17.02.2007, 17:53
Washington Washington вне форума
Прохожий
 
Регистрация: 14.02.2007
Сообщения: 29
Репутация: 10
По умолчанию

Разобрался я с этой ошибкой. Не смейтесь пожалуйста, но имена полей в таблице и в запросе не совпадали. Глупо, я знаю
__________________
Ну это нормально...
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter