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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.04.2011, 10:08
dimfan dimfan вне форума
Прохожий
 
Регистрация: 08.09.2009
Адрес: Гродно
Сообщения: 6
Репутация: 10
По умолчанию Есть вопрос по запросу

Есть запрос

query1.SQL.Clear;
query1.SQL.Add('SELECT Status.Status FROM Status INNER JOIN Users ON Status.id_Status = Users.Status;');
query1.ExecSQL;

Как занести результат выполнения запроса в переменную (результат должен быть admin или оператор)
Заранее спасибо
Ответить с цитированием
  #2  
Старый 14.04.2011, 10:09
Аватар для anonymous
anonymous anonymous вне форума
Новичок
 
Регистрация: 19.01.2011
Сообщения: 61
Версия Delphi: Delphi2009 v.12
Репутация: 12
По умолчанию

v:=querry1.fieldbyname('status')asstring;
Ответить с цитированием
  #3  
Старый 14.04.2011, 10:22
dimfan dimfan вне форума
Прохожий
 
Регистрация: 08.09.2009
Адрес: Гродно
Сообщения: 6
Репутация: 10
По умолчанию

не получается выдает ошибку: "query1: Field 'Status' not found"
Ответить с цитированием
  #4  
Старый 14.04.2011, 10:29
Black Raider Black Raider вне форума
Местный
 
Регистрация: 31.05.2010
Адрес: Москва
Сообщения: 466
Версия Delphi: 7
Репутация: 40
По умолчанию

Код:
query1.ExecSQL;
поменяйте на
Код:
query1.Open;
или
Код:
query1.Active:=true;
__________________
Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение"
Ответить с цитированием
  #5  
Старый 14.04.2011, 11:00
dimfan dimfan вне форума
Прохожий
 
Регистрация: 08.09.2009
Адрес: Гродно
Сообщения: 6
Репутация: 10
По умолчанию

Извините конечно же за тупость просто еще учусь програмировать но что тут не так

for i:=0 to tbl1.FieldCount-1 do
begin
if ((login_txt.Text <> tbl1.FieldByName('Login').AsString) or (passw_txt.Text <> tbl1.FieldByName('Password').AsString)) then
begin
tbl1.Next;
end
else
begin
count:=count+1;
query1.SQL.Clear;
query1.SQL.Add('SELECT Users.Status FROM Status INNER JOIN Users ON Status.id_Status = Users.Status;');
query1.Active:=true;
v:=query1.Fieldbyname('Status').AsString;
end;
end;

if count <> 0 then
begin
ShowMessage(v);// здесь он мне выдает постоянно первую запись выполненного запроса
....
form3.show;
end
Ответить с цитированием
  #6  
Старый 14.04.2011, 11:08
Black Raider Black Raider вне форума
Местный
 
Регистрация: 31.05.2010
Адрес: Москва
Сообщения: 466
Версия Delphi: 7
Репутация: 40
По умолчанию

Код:
tbl1.FieldCount
кол-во полей в наборе а не записей.(!!!)

Используйте repeat until или While для прохода по записям
например так:
Код:
if not adoquery1.isEmpty then begin
repeat
 adoquery1.next;
until adoquery1.eof;
end;

Вы уверены что тут or ?
Код:
if ((login_txt.Text <> tbl1.FieldByName('Login').AsString) or (passw_txt.Text <> tbl1.FieldByName('Password').AsString)) then
begin

Предполагаю что вы делаете форму авторизации... если да то проще сделать все ОДНИМ запросом и вернуть статус им же
__________________
Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение"
Ответить с цитированием
  #7  
Старый 14.04.2011, 11:57
dimfan dimfan вне форума
Прохожий
 
Регистрация: 08.09.2009
Адрес: Гродно
Сообщения: 6
Репутация: 10
По умолчанию

Спасибо очень помогли
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter