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

Вниз

Firebird и представления   Найти похожие ветки 

 
LoDr   (2007-12-27 17:31) [0]

Есть на клиенте запрос
"Select field1, field2 from MyView",
где MyView- представление,
который периодически открывается с пом. датасета(FIBPlus):
 With pFIBDataSet1 do
 begin
   Open;
   ...//Смотим че там происходит и закрываем!
   Close;
 end;


Проблема заключается в том, что если требуется изменить MyView и он был уже просмотрен на подключенном к базе клиенте(даже если запрос и закрыт), то IBExpert говорит:
"object MyView is in use".
Перекомпилить MyView можно только после отключения клиента.
Обьясните плз, где тут собаку зарыли), как можно "освободить" представление на клиенте?


 
Правильный_Вася   (2007-12-27 17:39) [1]

видимо, дело в том, что метаданные кэшируются
но т.к. такая проблема может возникнуть только на этапе разработки, не заморачивайся


 
LoDr   (2007-12-27 18:48) [2]

Дело в том, что не только на этапе, т.к. условия этого представления могут иногда меняться, а полные запросы клиентам дать не могу, так как не у всех есть они будут работать(из-за прав и внешних функций).

ЗЫ: Зачем же тогда эти представления, если толку от них...


 
atruhin ©   (2007-12-27 21:49) [3]

> Дело в том, что не только на этапе, т.к. условия этого представления
> могут иногда меняться,

В Firebird одно из основных правил: Нельзя менять метаданные во время работы программы.


 
Правильный_Вася   (2007-12-27 23:12) [4]


> условия этого представления могут иногда меняться

а что, нельзя заранее сделать много вьюх или накладывать условия на саму выборку из вьюхи?


 
Johnmen ©   (2007-12-28 08:48) [5]


> Дело в том, что не только на этапе, т.к. условия этого представления
> могут иногда меняться,

Значит что-то не так в консерватории.


 
Msguns ©   (2007-12-29 20:50) [6]

Вместо изменеоия вьюхи можно использовать параметры для варьирования условий выборки


 
DrPass ©   (2007-12-30 02:53) [7]


> ЗЫ: Зачем же тогда эти представления, если толку от них.
> ..

Как и в любой другой СУБД - для создания предопределенных выборок, но никак не средство для динамического исполнения запросов. В грамотно спроектированной базе данных не должно быть случаев изменения метаданных в рантайме.



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

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

Наверх




Память: 0.48 MB
Время: 0.016 c
15-1208744609
Slider007
2008-04-21 06:23
2008.06.01
С днем рождения ! 21 апреля 2008 понедельник


2-1210096869
Dron2
2008-05-06 22:01
2008.06.01
Если ошибка соединения - закрыть приложение. Как это сделать?


15-1208264263
Ega23
2008-04-15 16:57
2008.06.01
Коллеги, поможите чем можете :)


8-1180605691
First
2007-05-31 14:01
2008.06.01
MP3 проигрыватель


2-1210445090
Alexey
2008-05-10 22:44
2008.06.01
Как поменять местами появление форм