Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.02.17;
Скачать: [xml.tar.bz2];

Вниз

OleContainer   Найти похожие ветки 

 
Ермек   (2004-01-26 02:48) [0]

Помогите разобраться с компонентом OleContainer
Пусть имеется 3 таблицы:
Master таблица - Rasdel
Detail таблица - Question
SubDetail таблица - Answer
Для этих таблиц создал Компоненты :
pFIBDataSetRasdel ,pFIBDataSetQUESTION, pFIBDataSetAnswer

Провожу вставку в таблицу - Answer blob-данные (вордовский текст)
Таким образом
При нажатии кнопки «Новый»:
procedure TFormDesignTest.Button38Click(Sender: TObject);
begin
pFIBDataSetAnswer.Append;
OleContainer2.DestroyObject;
OleContainer2.InsertObjectDialog;
OleContainer2.Enabled:=true;
end;
end;

При нажатии кнопки «Сохранить»
procedure TFormDesignTest.Button41Click(Sender: TObject);
Var s:Tstream;
begin
//Запись в базу данных
Try
S:=pFIBDataSetAnswer.CreateBlobStream(pFIBDataSetAnswer.FieldByName("NAMEANSWER"),bmReadWrite);
OleContainer2.SaveToStream(S);
pFIBDataSetAnswer.Post;
finally
S.Free;
//чтение из базы данных в OleContainer
if not(pFIBDataSetAnswer.FieldByName("NAMEANSWER").IsNull) then
Try
S:=pFIBDataSetANSWER.CreateBlobStream(pFIBDataSetANSWER.FieldByName
("NAMEANSWER"),bmRead);
OleContainer2.LoadFromStream(S);
finally
S.Free;
end;
OleContainer2.Enabled:=false;

pFIBDataSetAnswer.Transaction.Commit;
pFIBDataSetRasdel.Open;
end;

При нажатии кнопки «Удалить»

procedure TFormDesignTest.Button40Click(Sender: TObject);
begin
OleContainer2.Enabled:=true;
pFIBDataSetAnswer.delete;
OleContainer2.DestroyObject;
OleContainer2.InsertObjectDialog;
OleContainer2.Enabled:=false;
end;

Вопросы такие;
1. Что надо изменить в коде чтобы при длительной вставки данных
Не возникло сообщение «не хватки памяти»?
2. Что можно сделать чтобы не выходила окошко выбора объектов а загружала сразу вордоский документ по клику по OleContainerу?
3. Что можно сделать чтобы окошко OleContainer было не серым а например белым?
4. Где можно найти инфу, который рассматривает случай когда существует 1Detail таблица и несколько Master таблицы для компонента pFIBDataSet


 
ЮЮ   (2004-01-26 04:24) [1]

1) Где можно найти инфу, который рассматривает случай когда существует 1Detail таблица и несколько Master таблицы для компонента pFIBDataSet

Здавый смысл такого не допускает :-)
Если только Detail таблица - это запрос с несколькими параметрами, часть из которых определяется по Master1, а другая по Master2, то следует отказаться от прямого указания Master-Detail связей и организовать их программно, обратывая, например, AfterScroll Master1 и Master2, устанавливая нужные параметры и переоткрывая запрос.


 
Ермек   (2004-01-27 01:31) [2]

Спасибо ЮЮ за ответ,
но все же Что надо изменить в коде чтобы при длительной вставки данных
Не возникло сообщение «не хватки памяти»?


 
ЮЮ   (2004-01-27 02:53) [3]

Кабы ещё знать, что ты прнимаешь под "длительной вставки данных".
А ещё лучше фрагмент кода



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

Форум: "Базы";
Текущий архив: 2004.02.17;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.012 c
4-53820
FBI
2003-12-08 09:41
2004.02.17
Активное окно


3-53356
Suntechnic
2004-01-27 19:23
2004.02.17
Oracle и транзакции.


1-53565
dima_crt
2004-02-09 10:46
2004.02.17
отладчик заходит в модуль компонента...


9-53354
lokid7
2003-08-03 15:57
2004.02.17
Вывод в DirectX


11-53437
dataMaster
2003-06-02 12:57
2004.02.17
Как распечатать форму?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский