Пятница, 08 Ноя 2024, 22:18
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Высшая математика [11]
Экономическая социология [95]
Основы Менеджмента [64]
Бухгалтерский учёт [157]
Философия [163]
Мировая Экономика [603]
Бизнес планирование [29]
Финансирование и кредитование инвест [105]
Ценообразование [46]
Гражданское право [196]
Права Человека [173]
Основы Маркетинга [207]
Основы энергосбережения [55]
Информатика [0]
Экология и устойчивое развитие [0]
Физика для студентов [0]
Основы права [0]
Политология [0]
Не стандартные примеры на Delphi [169]
Примеры на Delphi7 [108]
Алгоритмы [94]
API [110]
Pascal [152]
Базы Данных [6]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51642


Онлайн всего: 94
Гостей: 94
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

Каталог статей


Главная » Статьи » Студентам » Не стандартные примеры на Delphi

Формат и размер dBase-поля
Во время выполнения программы мне необходимо получать размеры и
десятичные порядки полей таблицы DBase.
Следующий код иллюстрирует необходимые вызовы BDE:

procedure GetdBaseFieldTypes( t : TTable; var l :
TStringList);
var
pF: pFLDDesc;
cProps: CURProps;
p: pFLDDesc;
i: Byte;
w : Word;
s : string;
oldmode : LongInt;
begin
Check(DbiGetCursorProps(t.Handle,cProps));
Check(DbiGetProp(hDBIObj(t.Handle),curXLTMODE,oldmode,SizeOf(LongInt),w));
Check(DbiSetProp(hDBIObj(t.Handle), curXLTMODE,
LongInt(xltNONE)));
try
if MaxAvail < (cProps.iFields*SizeOf(FLDDesc))
then
raise EOutofMemory.Create('Недостаточно
памяти для процесса');
GetMem(pF,(cProps.iFields*SizeOf(FLDDesc)));
Check(DbiGetFieldDescs(t.Handle,pF));
p := pF;
for i := 1 to cProps.iFields
do begin
with p^ do begin
s := IntToStr(iFldNum)+' :
'+StrPas(szName)+' : ';
case iFldType of
fldDBCHAR : begin { Char string,
строка символов }
s := s + 'CHARACTER('+IntToStr(iUnits1)+')';
end;
fldDBNUM : begin { Number, число
}
s := s + 'NUMBER('+IntToStr(iUnits1)+','+InttoStr(iUnits2)+')';
end;
fldDBMEMO : begin { Memo (blob),
МEMO-BLOB-поле }
s := s + 'MEMO';
end;
fldDBBOOL : begin { Logical,
лочическая величина }
s := s + 'LOGICAL';
end;
fldDBDATE : begin { Date, поле даты
}
s := s + 'DATE';
end;
fldDBFLOAT : begin { Float, числа с
плавающей точкой }
s := s + 'FLOAT('+IntToStr(iUnits1)+','+InttoStr(iUnits2)+')';
end;
fldDBLOCK : begin { Логический тип
LOCKINFO }
s := s + 'LOCKINFO';
end;
fldDBOLEBLOB : begin { OLE object
(blob), OLE-объект, BLOB-поле }
s := s + 'OLE';
end;
fldDBBINARY : begin { Binary data
(blob), двоичные данные, BLOB-поле }
s := s + 'BINARY';
end;
else
s := s + 'НЕИЗВЕСТНО';
end;
end;
l.Add(s);
Inc(p);
end;
finally
Check(DbiSetProp(hDBIObj(t.Handle),curXLTMODE,oldmode));
FreeMem(pF,(cProps.iFields*SizeOf(FLDDesc)));
end;
end;
Категория: Не стандартные примеры на Delphi | Добавил: Lerka (22 Ноя 2012)
Просмотров: 437 | Рейтинг: 1.0/ 4 Оштрафовать | Жаловаться на материал
Похожие материалы
Всего комментариев: 0

Для блога (HTML)


Для форума (BB-Code)


Прямая ссылка

Профиль
Пятница
08 Ноя 2024
22:18


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Главная страница
Используются технологии uCoz