Следующий код иллюстрирует необходимые вызовы BDE:
procedure GetdBaseFieldTypes( t : TTable; var l : TStringList);varpF: pFLDDesc;cProps: CURProps;p: pFLDDesc;i: Byte;w : Word;s : string;oldmode : LongInt;beginCheck(DbiGetCursorProps(t.Handle,cProps));Check(DbiGetProp(hDBIObj(t.Handle),curXLTMODE,oldmode,SizeOf(LongInt),w));Check(DbiSetProp(hDBIObj(t.Handle), curXLTMODE, LongInt(xltNONE)));tryif MaxAvail < (cProps.iFields*SizeOf(FLDDesc)) thenraise EOutofMemory.Create('Недостаточно памяти для процесса');GetMem(pF,(cProps.iFields*SizeOf(FLDDesc)));Check(DbiGetFieldDescs(t.Handle,pF));p := pF;for i := 1 to cProps.iFields do beginwith p^ do begins := IntToStr(iFldNum)+' : '+StrPas(szName)+' : ';case iFldType offldDBCHAR : 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;elses := s + 'НЕИЗВЕСТНО';end;end;l.Add(s);Inc(p);end;finallyCheck(DbiSetProp(hDBIObj(t.Handle),curXLTMODE,oldmode));FreeMem(pF,(cProps.iFields*SizeOf(FLDDesc)));end;end; |
- Eryk Bottomley [000830]