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

Вниз

Как сохранять содержимое файлов в БД и обратно ?   Найти похожие ветки 

 
NewD   (2003-11-06 13:38) [0]

имеется поле VARBINARY исползую ADO

и я в него сохраняю содержимое файла через Tstream

для сохранения в БД:

procedure TForm1.Button1Click(Sender: TObject);
var stream:tadoblobstream;
begin
try
ADODataSet1.Append;
if opendialog1.Execute then
begin
stream:=tadoblobstream.Create(tblobfield (ADODataSet1.FieldByName("BlOBFIELD")),bmReadWrite);
stream.LoadFromFile(opendialog1.FileName);
end;
ADODataSet1.Post;
except
on e:exception do showmessage(e.Message);
end ;
stream.free;
end;


для сохранения в файл

procedure TFormDOC.Button2Click(Sender: TObject);
var stream:tadoblobstream;
i:integer;
begin
try
if savedialog1.Execute then
begin
ADODataSet1.Edit;
stream:=tadoblobstream.Create(tblobfield(ADODataSet1.FieldByName("BlOBFIELD")),bmread);
stream.savetofile(savedialog1.FileName);
ADODataSet1.cancel;
end;
except
on e:exception do showmessage(e.Message);
end ;
stream.free;
end;

ошибок нет но почему то сохраняет 0 байт в файле,
что не так ?
или он не грузит в базу данные из файла ?


 
sniknik ©   (2003-11-06 13:51) [1]

просто
tblobfield(ADODataSet1.FieldByName("BlOBFIELD")).savetofile(savedialog1.FileName);
попробуй, и аналогично чтение.


 
NewD   (2003-11-06 13:54) [2]

я уже пробовал при сохранении выдает ошибку:
Invalid class Typecast


 
sniknik ©   (2003-11-06 14:22) [3]

так это уже несответствие типов, может и ноль байт записывало потомуже, поменяй тип поля на blob (image к примеру).
посмотрел, у TBinaryField вообще нет stream-а (а приводится по типу к нему)



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

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

Наверх




Память: 0.47 MB
Время: 0.028 c
1-89988
Nikos
2003-11-18 09:15
2003.11.27
Разрыв связи с файловой переменной.


3-89764
andrey__
2003-11-07 16:05
2003.11.27
Метод Locate


14-90125
kovalski
2003-11-03 06:52
2003.11.27
про сотовые


6-90034
Garin
2003-09-11 12:33
2003.11.27
Отправка почты (SMS)


3-89730
Vladimir_
2003-11-09 20:03
2003.11.27
цвет и толщина линий Dbgrid