Имеется проблема с записью/чтением jpeg изображений в базу данных Access.
Программа в начале создает mdb файл с несколькими таблицами.
Одна из таблиц создается следующим запросом:
Код:
ADOQuery1.SQL.Text := 'create table about_corp (info text, logotype image);';
По замыслу таблица содержит перечень информации о разных фирмах и их логотипы. После создания mdb файла и его заполнения база сохраняется и в дальнейшем используется для редактирования и создания специальных отчетов.
Суть проблемы в том, что так или иначе приходится подгружать изображение в 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;
Перелазил весь Google так ничего толком и не нашел. Помогите найти и исправить ошибку.