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

Вниз

Смысл типа TVarBytesField   Найти похожие ветки 

 
programmer1   (2002-02-12 10:22) [0]

Уважаемые коллеги, скажите, пожалуйста, что означает тип поля TVarBytesField, какого типа данные можно в нем хранить. В книге Фаронова написано:
"Поле TVarBytesField содержит произвольное значение длиной до 65535 байт. Текущая длина хранится в первых двух байтах и может быть получена с помощью свойства Datasize"
Поясните мне, пожалуйста, смысл этих магических слов!


 
Digitman (M)   (2002-02-12 12:24) [1]

TVarBytesField - класс, инкапсулирующий ф-ции управления полями объектов БД, предназначенными для хранения данных переменной длины, не превышающей 64кб. В полях такого типа физически хранятся не только сами данные, но и инф-ция о реальном их размере. Вот этот самый реальный размер и представлен св-вом Datasize.
Когда в поле такого типа записываются некие данные (в виде блока последовательных байт), то сначала записывается размер блока (те самые первые первые 2 байта), а затем записывается собственно блок.
Когда из поля такого типа считываются ранее записанные туда данные, то сначала считываются первые 2 байта (их значение, интерпретируемое как WORD, становятся зн-ем св-ва TVarBytesField.Datasize), а затем в выделенный буфер размером в Datasize + 2 считываются данные, включая первые служебные 2 байта. Т.е. в буфере данных такого поля по смещению +0 хранится слово, значение которого информирует о размере собственно данных, по смещению +2 - собственно блок данных указанного по смещению +0 размера (в байтах).


 
Programmer1   (2002-02-14 11:26) [2]

Спасибо за полный ответ.



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

Форум: "Основная";
Текущий архив: 2002.03.04;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.44 MB
Время: 0.005 c
3-9097
vopros
2002-02-06 10:45
2002.03.04
надо показать из базы сумму по некоторым полям...


1-9175
Dimedrol
2002-02-12 13:10
2002.03.04
Stay on top v.s. MessageDlg ?!


3-9084
karafuto
2002-02-07 10:10
2002.03.04
Глюк клиента MS SQL 2000?


14-9289
mvg_first
2002-01-10 13:38
2002.03.04
Пара предложений для Мерлина (присоединяйтесь!)


1-9108
Igl
2002-02-15 21:50
2002.03.04
Как можно сделать эквалайзер?





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