Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.04.25;
Скачать: [xml.tar.bz2];

Вниз

Запись массива в бинари в blob поле в БД в MSACCESS   Найти похожие ветки 

 
Yozh_Programmer ©   (2004-03-29 23:39) [0]

Вот есть код
записи данных в БД с blob"ом

procedure TForm1.Button1Click(Sender: TObject);
var arI : array[ 1..3 ] of Integer;
   ms : TMemoryStream;
begin
   a_q.SQL.Text := "insert into bin_table values( :_bin_field )";
   a_q.Parameters.ParamByName( "_bin_field" ).DataType := ftBLOB;
   a_q.Parameters.ParamByName( "_bin_field" ).Size := SizeOf( Integer ) * 3;
   ArI[ 1 ] := StrToInt( Edit2.Text );
   ArI[ 2 ] := StrToInt( Edit3.Text );
   ArI[ 3 ] := StrToInt( Edit4.Text );
   ms := TMemoryStream.Create();
   ms.Write( ArI, Sizeof( Integer ) * 3 );
   a_q.Parameters.ParamByName( "_bin_field" ).LoadFromStream( ms, ftBLOB );
   a_q.ExecSQL();
   ms.Destroy();
end;

теперь считывание

procedure TForm1.Button2Click(Sender: TObject);
var i, Count : Integer;
   ms : TMemoryStream;
   ArI : array[ 1..3 ] of Integer;
   _s : String;
begin
   ms := TMemoryStream.Create();
   lv.Clear(); // TListView
   a_q.SQL.Text := "select * from bin_table order by id";
   a_q.Open();
   Count := a_q.RecordCount;
   for i := 1 to Count do
   begin
       ( a_q.FieldByName( "bin_field" ) as TBlobField ).SaveToStream( ms );
       ms.Read( ArI, ms.Size );
       _s := IntToStr( ArI[ 1 ] ) + "; " + IntToStr( ArI[ 2 ] ) + "; " + IntToStr( ArI[ 3 ] );
       lv.Items.Add().Caption := _s;
       a_q.Next();
   end;
   a_q.Close();
   ms.Destroy();
end;

короче, что не добавляю показывает одни и теже значения, что я делаю не верно???


 
sniknik ©   (2004-03-30 08:41) [1]

попробуй позицию задавать перед обрашением
...
ms.Write( ArI, Sizeof( Integer ) * 3 );
ms.Position:= 0;
...

ms.Position:= 0;
ms.Read( ArI, ms.Size );

и пользуйся ReadBuffer (хоть ошибку покажет если несработает)
и поменяй ms.Destroy(); на ms.free;



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

Форум: "Базы";
Текущий архив: 2004.04.25;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 1.665 c
3-1080798595
-+= Evgeney =+-
2004-04-01 09:49
2004.04.25
Запрос SQL


1-1081597997
MAXH0
2004-04-10 15:53
2004.04.25
Подскажите алгоритм создания списка в алфавитном порядке


8-1073224124
Demian3797
2004-01-04 16:48
2004.04.25
Векторная графика


7-1073774726
murdor
2004-01-11 01:45
2004.04.25
Комнонент для работы с LPT


14-1080757008
gn
2004-03-31 22:16
2004.04.25
хочу похвастатся моя любимая написала первую программу





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский