|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
|||
|
|||
Сохранение Jpeg в Access
Имеется проблема с записью/чтением jpeg изображений в базу данных Access.
Программа в начале создает mdb файл с несколькими таблицами. Одна из таблиц создается следующим запросом: Код:
ADOQuery1.SQL.Text := 'create table about_corp (info text, logotype image);'; Суть проблемы в том, что так или иначе приходится подгружать изображение в TImage, а оно не читается из базы. Более того, я вообще сомневаюсь что оно туда пишется. Алгоритм прост: сначала выбирается файл, который загружается в TImage, затем данные сохраняются нажатием кнопки сохранения. Вот код, который выполняется при нажатии кнопки. Код:
procedure Ttitle_form.AC_SaveClick(Sender: TObject); var logotype : TMemoryStream; blobstream : TADOBlobStream; logo_jpeg : TJPEGImage; begin logotype := TMemoryStream.Create; try Image1.Picture.Bitmap.SaveToStream(logotype); ADOQuery1.Close; ADOQuery1.SQL.Text := 'insert into about_corp (info, logotype) values (:inform, :img);'; ADOQuery1.Parameters.ParamByName('inform').Value := about_corp.Lines.Text; ADOQuery1.Parameters.ParamByName('img').LoadFromStream(logotype, ftDBaseOle); ADOQuery1.ExecSQL; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Text := 'select logotype from about_corp;'; ADOQuery1.Open; if not ADOQuery1.FieldByName('logotype').IsNull then begin try blobstream := TADOBlobStream.Create(TBlobField(ADOQuery1.FieldByName('logotype')), bmRead); logo_jpeg := TJPEGImage.Create; logo_jpeg.LoadFromStream(blobstream); Image1.Picture.Assign(logo_jpeg); except ShowMessage('Error'); end; end; finally FreeAndNil(logotype); ADOQuery1.SQL.Clear; end; end; |
#2
|
|||
|
|||
Вот моя тема , там сохранение bmp в базу... думаю разницы нету ...
Я решил этот вопрос так |
#3
|
|||
|
|||
А нельзя по проще, для чайника или простенький исходник?
|