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

Вниз

НЕсовершенство Interbase ?   Найти похожие ветки 

 
Malder ©   (2002-03-15 16:25) [0]

Я тут недавно писал про невозможность UPDATE"а Blob поля. Дело оказалось немного не в том.
Рассказываю заново и подробно.

Есть какая-то таблица Table1. В ней есть Blob поле, допустим оно зовется fdBlob. Делаем обзор для таблицы в котором среди прочего включаем этот fdBlob из Table1. Тут то и начинается самое интересное. Мне нужен обзор из-за того, что я пишу

Create View view1 as
...
fdBlob from Pers
Where Manager = User
With Check Option
.

То есть, обращаясь к обзору, юзер может получить доступ только к полям, где Manager равно имени пользователя.

И все бы хорошо, но если поставить этот самый With Check Option, то нельзя сделать коммнду UPDATE для обзора. Interbase начинает ругаться на Blob поле (говорит, что Blob не поддерживает Compare операции).
Если не писать With Check Option - то все ОК.

Отсюда вопрос. Что произойдет, если не писать его ? Уменьшится ли безопасность ?
И вообще, можно ли бороться с данным неудобством ?

P.S. Если что непонятно - спрашивайте... сам понимаю, что вопрос не из легких...


 
OlegE ©   (2002-03-15 16:41) [1]

Вместо view сделай процедуру, ей передаешь параметр Manager, или прямо в теле процедуры определяй user, и возвращай только то что нужно.


 
Malder ©   (2002-03-15 19:54) [2]

Давайте так. ЧТО изменится, если я не буду писать для обзора With Check Option ?


 
evgeg ©   (2002-03-15 20:58) [3]

Не советую вообще использовать View в Interbase. Глючит.


 
Malder ©   (2002-03-15 23:47) [4]

А что же делать, если не пользоваться обзорами ?

И что, действительно сильно глючит ?


 
Johnmen ©   (2002-03-16 00:09) [5]

>evgeg © : Не надо грязи - ничего не глючит !
А если ты это утверждаешь, то докажи !
>Malder © : В твоей ситуацией не сталкивался...


 
evgeg ©   (2002-03-16 06:22) [6]

> Johnmen
После создания процедуры с select-м из view и таблицы перестало выполнятся restore. Слышал и о других глюках. Доказывать тебе ничего не собираюсь. Я отвечал человеку, задавшему вопрос.

>Malder
Пользуйся хранимыми процедурами.


 
Malder ©   (2002-03-16 12:18) [7]

Ок. А как тогда в процедуру передать параметр типа Blob ?


 
evgeg ©   (2002-03-16 13:13) [8]

Я с blob-ми в процедурах не работал, но разве так не проходит?


CREATE PROCEDURE NEW_PROCEDURE (
B1 BLOB)
AS
begin
/* Procedure Text */
suspend;
end



 
Igor' A Rozhkov   (2002-03-16 16:09) [9]

В Interbase,возможно необновляемый View превратить в обновляемый написав для него триггера Before Insert, Delete, Update, как если бы это была обычная таблица


 
ka$per   (2002-03-18 10:42) [10]

>Malder
С передачей Blob все просто
var
proc:TStoredProc;
FStream:TStream;

...
proc.ParamByName("NameParam").LoadFromStream(FStream,ftBlob);



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

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

Наверх




Память: 0.49 MB
Время: 0.011 c
14-22804
Song
2002-02-26 17:51
2002.04.08
Скажите за что зацепиться. Нужно узнать выключен ли монитор.


7-22851
ALex J@m
2001-12-07 07:16
2002.04.08
Переход в ждущий или спящий режим в Win 2k


3-22522
Eduard
2002-03-14 11:07
2002.04.08
Table unknown


3-22550
Dok_3D
2002-03-14 15:18
2002.04.08
Этот хитрый FOR XML AUTO .......


1-22704
Ghost12
2002-03-26 14:37
2002.04.08
Ещё раз про HTML форму, люди помогите реально, дайте путный совет.