Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.02.13;
Скачать: CL | DM;

Вниз

Гранты, TIBDataSet и его Prepare   Найти похожие ветки 

 
eugie   (2004-01-21 16:46) [0]

Уважаемые Мастера! Столкнулся с такой проблемой. В приложении используются компоненты TIBDataSet с запросами на SELECT, REFRESH, INSERT, UPDATE, DELETE (т.е. "live query"). Их довольно много, кроме того, некоторые еще и создаются в run-time. Так вот, при подключении к БД под именем пользователя, имеющего ограниченные права на объекты БД (например только SELECT и REFERENCE) сервером выдается ошибка при выполнении IBDataSet.Open типа "нет прав на вставку/обновление". Причина - при выполнении метода (IBDataSet.Open) выполняется метод Prepare для каждого из запросов компонента (смотрел исходник) - как следствие - возникновение ошибки. Подскажите, есть ли какие-либо другие компонеты, у которых Prepare выполняется отдельно для каждого из запросов непосредственно при его использовании? Или есть пути для обхода данного затыка? Просто переделывать сильно много, хочется "малой кровью" обойтись...


 
Sandman25 ©   (2004-01-21 16:56) [1]

ReadOnly/RequestLive (или как его там для IB компонент) указан верно?


 
Johnmen ©   (2004-01-21 17:01) [2]

>eugie

Малой кровью - подправить исходники :)
Закомментарь препарирование...


 
eugie   (2004-01-21 17:25) [3]

>Sandman25
Таких свойств нет

>Johnmen

Закоментарить - не пойдет: подключающийся пользователь может иметь права на изменение объекта БД. Есть конечно такая идея - последовательно делать попытки выполнения TIBDataSet.Open и в зависимости от кода ошибки выносить тексты из запросов на INSERT, UPDATE и DELETE. Но тогда возникает проблема востановления таковых при смене пользователя. Геморрой, короче.


 
Sandman25 ©   (2004-01-21 17:28) [4]

Я думаю, Johnmen имел ввиду, чтобы Prepare вызывался при их первом использовании, а не TIBDataSet.Open.


 
Johnmen ©   (2004-01-21 17:32) [5]

>Sandman25 © (21.01.04 17:28)

Точно :)


 
Sandman25 ©   (2004-01-21 17:35) [6]

[5] Johnmen © (21.01.04 17:32)

Вот видишь... Сегодня не пятница и не 13-ое, и мы опять друг друга понимаем :)


 
eugie   (2004-01-21 17:40) [7]

Именно это и надо. Путей 2: "нарисовать" новую компонету на основе TIBDataSet с переопределением метода Prepare и необходимых свойств или изменить стандартный. Вот я и спросил, может уже кто сделал подобное?


 
Sandman25 ©   (2004-01-21 17:47) [8]

Я тут поковырялся по исходникам... Вроде бы prepare происходит только при наличии соответствующего SQL. Можно попытаться определять права пользователя заранее (до открытия Dataset) и присваивать только те SQL (Insert, update, delete), на которые есть доступ.


 
eugie   (2004-01-22 04:54) [9]

Так и есть. Я тоже начал склоняться к этому варианту.



Страницы: 1 вся ветка

Текущий архив: 2004.02.13;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.041 c
1-38929
turonix
2004-02-04 11:53
2004.02.13
Как из функции вне класса запустить обработчик события в классе?


3-38683
Volodya_
2004-01-22 17:35
2004.02.13
Refresh


1-38910
Dik
2004-02-04 14:45
2004.02.13
Текстовый редактор


1-38789
Александр
2004-02-04 19:30
2004.02.13
Построение графиков


3-38669
Крутыш
2004-01-24 21:32
2004.02.13
Проблемы с запросом.