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

Вниз

чтение параметров из blolb   Найти похожие ветки 

 
stud ©   (2005-06-10 11:13) [0]

есть blob поле, в катором хранятся параметры в виде как в ини-файле,
как считать эти данные в локальные переменные?


 
Ega23 ©   (2005-06-10 11:29) [1]

ms:=TMemoryStream.Create;
TBLOBField(DataSet.FieldByName("FieldName")).SaveToStream(ms);
ms.readBuffer(...)


 
stud ©   (2005-06-10 11:35) [2]

это уже написал
но как определить размер считываемых данных?
параметры имеют разную длину, например
timestart="00:00"
datestart="01.01.2005"


 
Ega23 ©   (2005-06-10 11:51) [3]

А как ты их в blob писал? Вот как писал, так и считывать надо.
Могу предложить следующее (сам недавно реализовал):
данные в BLOB пишутся в формате, похожим на формат Tiff -
есть чёткая структура тэгов

TGfxTagStruct = packed record
 Tag           : Word;
 wParam        : Cardinal;
 lParam        : Cardinal;
 Offset        : Cardinal;
end;


где
Tag - номер тэга,
wParam, lParam - могут быть разные значения, зависящие от номера тэга,
 Offset - позиция следующего тэга относительно начала BLOB"а.

Скажем, тэг, отвечающий за хранение картинки (bmp) будет выглядеть так:
Tag - номер (например 10)
lParam - размер картинки
wParam - позиция начала картинки относительно начала BLOB"а
Offset - позиция следующего тэга относительно начала BLOB"а (если последний - то 0)

тэг, отвечающий за цвет фонта будет выглядеть так:
Tag - номер (например 12)
lParam - для данного тэга не используется
wParam - размер фонта
Offset - позиция следующего тэга относительно начала BLOB"а (если последний - то 0)

тэг, отвечающий за какую-то строку будет выглядеть так:
Tag - номер (например 15)
lParam - размер строки
wParam - указатель на начало строки
Offset - позиция следующего тэга относительно начала BLOB"а (если последний - то 0)

и так далее.


 
stud ©   (2005-06-10 12:00) [4]

понятно


 
Digitman ©   (2005-06-10 12:49) [5]

ss:=TStringStream.Create;
TBLOBField(DataSet.FieldByName("FieldName")).SaveToStream(ss);
ini := TMemIniFile.Create("");
ini.SetStrings(ss.DataString);


 
stud ©   (2005-06-10 13:51) [6]


> DataString

неесовместимые типы

> SetStrings


 
Digitman ©   (2005-06-10 14:00) [7]

ss:=TStringStream.Create;
TBLOBField(DataSet.FieldByName("FieldName")).SaveToStream(ss);
ini := TMemIniFile.Create("");
sl := TStringList.Create;
sl.Text := ss.DataString;
ini.SetStrings(sl);


 
stud ©   (2005-06-10 14:11) [8]

спасибо



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

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

Наверх





Память: 0.46 MB
Время: 0.012 c
1-1120473179
Kolan
2005-07-04 14:32
2005.07.25
Как разрешить изменять текст в StringGrid и как получить Reсt


3-1118894388
Dron1173
2005-06-16 07:59
2005.07.25
Аварийное закрытие приложения


3-1118315755
stelius
2005-06-09 15:15
2005.07.25
SQL запрос без раздела WHERE


14-1120483185
ПЛОВ
2005-07-04 17:19
2005.07.25
Что делать ума не приложу!


14-1120124105
stone
2005-06-30 13:35
2005.07.25
Hello, World. На разных языках





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский