Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 23.08.2009, 03:47
spidergrasp spidergrasp вне форума
Прохожий
 
Регистрация: 17.08.2009
Сообщения: 2
Репутация: 10
Восклицание Сохранение Jpeg в Access

Имеется проблема с записью/чтением 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 так ничего толком и не нашел. Помогите найти и исправить ошибку.
Ответить с цитированием
  #2  
Старый 23.08.2009, 07:07
ApxaHGe1 ApxaHGe1 вне форума
Активный
 
Регистрация: 08.04.2008
Адрес: Нижний новгород
Сообщения: 311
Репутация: 38
По умолчанию

Вот моя тема , там сохранение bmp в базу... думаю разницы нету ...

Я решил этот вопрос так
Ответить с цитированием
  #3  
Старый 02.10.2009, 08:29
Слесарь Слесарь вне форума
Прохожий
 
Регистрация: 02.10.2009
Сообщения: 1
Репутация: 10
По умолчанию

А нельзя по проще, для чайника или простенький исходник?
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 04:55.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter