Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  3 877

•  TDictionary Custom Sort  5 982

•  Fast Watermark Sources  5 771

•  3D Designer  8 587

•  Sik Screen Capture  6 114

•  Patch Maker  6 541

•  Айболит (remote control)  6 535

•  ListBox Drag & Drop  5 400

•  Доска для игры Реверси  95 229

•  Графические эффекты  6 749

•  Рисование по маске  5 910

•  Перетаскивание изображений  4 924

•  Canvas Drawing  5 299

•  Рисование Луны  5 028

•  Поворот изображения  4 570

•  Рисование стержней  3 243

•  Paint on Shape  2 484

•  Генератор кроссвордов  3 367

•  Головоломка Paletto  2 681

•  Теорема Монжа об окружностях  3 450

•  Пазл Numbrix  2 279

•  Заборы и коммивояжеры  2 965

•  Игра HIP  1 929

•  Игра Go (Го)  1 845

•  Симулятор лифта  2 180

•  Программа укладки плитки  1 912

•  Генератор лабиринта  2 350

•  Проверка числового ввода  2 038

•  HEX View  2 358

•  Физический маятник  1 990

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Формат и размер dBase-поля



Автор: Eryk Bottomley

Во время выполнения программы мне необходимо получать размеры и десятичные порядки полей таблицы 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;





Похожие по теме исходники

Аудио Деформатор

Линейная интерполяция функции

Интерполяция сплайнами




Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте