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

Вниз

как корректно записать объект OLE в поле БД?   Найти похожие ветки 

 
DBDev   (2003-05-15 11:44) [0]

для TOleContainer объекта?

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

OleClassName - возвращает имя класса, а не расширение файла.
Последнее нужно для корректной записи поля в БД. Как получить расширение файла для объекта OLE?

if (DocContainer->InsertObjectDialog() == IDOK) {
AnsiString fn = DocContainer->OleClassName;
GExt = НАДО ПОЛУЧИТЬ РАСШИРЕНИЕ ФАЙЛА (для СМ. ниже)
}


Запись в файл:

AnsiString file;

if (osEmpty != DocContainer->State) {
char buff[255];
GetEnvironmentVariable("TEMP", buff, sizeof(buff));
file = AnsiString(buff) + AnsiString("\\temp") + GExt;

DocContainer->OleObject.Exec(Procedure("SaveAs") << file);
Query->Edit();
((TBlobField *)Query->FieldByName("BLOB"))->LoadFromFile(file);
Query->FieldByName("DocumentExt")->AsString = GExt;
Query->Post();

DeleteFile(file);
}


 
DBDev   (2003-05-15 12:01) [1]

Или как иным способом "сказать" объекту OLE запишись в поле БД а не в файл???



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

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

Наверх




Память: 0.46 MB
Время: 0.014 c
14-3116
Axis_of_Evil
2003-05-14 14:03
2003.06.02
stdcall


14-3058
Dim!S
2003-05-15 07:14
2003.06.02
Исходники всегда с собой! :)


14-3047
DDDeN
2003-05-13 13:51
2003.06.02
DelphiX для Delphi 6


14-3149
Карелин Артем
2003-05-15 11:50
2003.06.02
Материалы по радиолокации. Где найти?


6-3042
DukeNukem
2003-04-01 17:40
2003.06.02
Работа с IMAP4