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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 03.03.2016, 22:30
starcon starcon вне форума
Новичок
 
Регистрация: 15.03.2014
Сообщения: 84
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Права доступа и активация некоторых Button

Очень нужно такую процедуру применить .

Есть таблица в ДБ, в ней есть столбцы
1.Имя
2.Пароль
3.Тип доступа (Администратор,Оператор, Пользователь)

Суть такая , клиент логиница и в зависимости от типа доступа ,активируются некоторые button.

Можно примерчик.

Спасибо
Ответить с цитированием
  #2  
Старый 03.03.2016, 23:19
ApxaHGe1 ApxaHGe1 вне форума
Активный
 
Регистрация: 08.04.2008
Адрес: Нижний новгород
Сообщения: 311
Репутация: 38
По умолчанию

Код:
Adoquery.sql text:='select privilegue from db where username ="123"';
Adoquery.open;
Priv:=ADODataSet1.Fields[0].AsString;
If priv='adm' then
Begin

End;

Последний раз редактировалось ApxaHGe1, 03.03.2016 в 23:30.
Ответить с цитированием
Этот пользователь сказал Спасибо ApxaHGe1 за это полезное сообщение:
starcon (04.03.2016)
  #3  
Старый 04.03.2016, 22:53
starcon starcon вне форума
Новичок
 
Регистрация: 15.03.2014
Сообщения: 84
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Завтра Попробую
Ответить с цитированием
  #4  
Старый 08.03.2016, 20:46
starcon starcon вне форума
Новичок
 
Регистрация: 15.03.2014
Сообщения: 84
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Можно описать более подробнее алгоритм .
У меня ругается на
Код:
Priv:=ADODataSet1.Fields[0].AsString;
Понимаю ,что надо объявить переменную
Ответить с цитированием
  #5  
Старый 08.03.2016, 22:19
ApxaHGe1 ApxaHGe1 вне форума
Активный
 
Регистрация: 08.04.2008
Адрес: Нижний новгород
Сообщения: 311
Репутация: 38
По умолчанию

Опечатка была
Вот
Код:
Priv:=ADOQuery1.Fields[0].AsString
Ответить с цитированием
  #6  
Старый 08.03.2016, 22:37
starcon starcon вне форума
Новичок
 
Регистрация: 15.03.2014
Сообщения: 84
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Всё равно не работает
Undeclared identifier: 'Priv'
Ответить с цитированием
  #7  
Старый 09.03.2016, 18:54
ApxaHGe1 ApxaHGe1 вне форума
Активный
 
Регистрация: 08.04.2008
Адрес: Нижний новгород
Сообщения: 311
Репутация: 38
По умолчанию

Var
Priv:string;
Ответить с цитированием
  #8  
Старый 12.03.2016, 16:25
starcon starcon вне форума
Новичок
 
Регистрация: 15.03.2014
Сообщения: 84
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Код:
Var
Priv:string;
begin
form8.ADOQuery1.sql.text:='select privilegue from pol where name ="123"';
form8.ADOQuery1.open;
Priv:=ADODataSet1.Fields[0].AsString;
If priv='Администратор' then
Begin

End;
end;
Пользователь 123 есть в базе
Столбы
1.privilegue (Администратор, Пользователь)
2.name (123, 234)
Таблица pol

Ругается на
List index out of bounds (0)

Последний раз редактировалось starcon, 12.03.2016 в 16:34.
Ответить с цитированием
  #9  
Старый 12.03.2016, 16:46
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

1. Вы считаете, что запрос у вас всегда будет возвращать результат, но это не так, поэтому надо проверять сначала есть ли там что-то, а уже потом пробовать обращаться к данным:
Код:
form8.ADOQuery1.sql.text:='select privilegue from pol where name ="123"';
form8.ADOQuery1.open;
if form8.ADOQuery1.isEmpty then Exit;
2. Обращаться к полю таблицы по индексу можно, но только в том случае, если у вас структура этой таблицы будет 100% нерушима. А вот в процессе разработки это лучше делать по имени поля:
Код:
Priv := ADODataSet1.FieldByName('privilegue').AsString;
или так:
Код:
Priv := ADODataSet1.FieldByName('privilegue').Value;
или так:
Код:
Priv := ADODataSet1['privilegue']; 
каждый из вариантов удобен по своему
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #10  
Старый 12.03.2016, 16:47
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Ну и еще момент. Вы уверены, что строку в запросе вам надо брать в двойные кавычки? Разные базы данных по разному хотят видеть строку.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
starcon (12.03.2016)
  #11  
Старый 12.03.2016, 18:49
starcon starcon вне форума
Новичок
 
Регистрация: 15.03.2014
Сообщения: 84
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Спасибо .
Только на двойные кавычки не ругается, на одинарные ругается.

Перепробовал все Ваши варианты
Ошибка одна
ADODataSet1:Field'privilegue' not found

что то я делаю не так

Последний раз редактировалось starcon, 12.03.2016 в 19:01.
Ответить с цитированием
  #12  
Старый 12.03.2016, 20:50
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Да всё нормально работает, может просто невнимательность (видимо пропустили 5й пост), вот пример
Вложения
Тип файла: zip starcon.zip (12.6 Кбайт, 4 просмотров)
Ответить с цитированием
Этот пользователь сказал Спасибо Alegun за это полезное сообщение:
starcon (13.03.2016)
  #13  
Старый 12.03.2016, 21:30
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Вот я сразу и не обратил внимание, у вас вообще чехарда с источниками.
Запрос вы делаете через Adoquery, а вот данные вы пытаетесь получить уже через ADODataSet1, я и написал в примере ADODataSet1.
Разберитесь уж сами что и откуда вы берете.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
starcon (13.03.2016)
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter