Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.02.20;
Скачать: CL | DM;

Вниз

Структура dbf файла   Найти похожие ветки 

 
Arrows   (2005-01-25 09:24) [0]

Здравствуйте. Не подскажите как в Delphi определить размерность чилового поля - FLoat уже существующей базы данных DbaseIV?


 
Reindeer Moss Eater ©   (2005-01-25 09:40) [1]

Её не надо определять. Она фиксирована.


 
Arrows   (2005-01-25 09:48) [2]

Фиксированная, но нужно узнать в проге какой размер имеет данное числовое поле, его формат.


 
Johnmen ©   (2005-01-25 09:52) [3]

TField.DataType
А зачем это надо ?


 
Arrows   (2005-01-25 10:07) [4]

Johnmen
TField.DataType-
А зачем это надо ?

Размерность поля - Пример Num : 15.2
Надо для преобразования любой базы DBaseIV в другой формат. Размерность.


 
Reindeer Moss Eater ©   (2005-01-25 10:38) [5]

У флоат полей нет никакой размерности. Это плавающая точка.
А размер в байтах фиксирован.
Поэтому Size и Precision вернут нули.


 
Arrows   (2005-01-25 11:01) [6]

Reindeer Moss Eater
У флоат полей нет никакой размерности. Это плавающая точка

Тогда как прочитать точную структуру dbf-файла?


 
Reindeer Moss Eater ©   (2005-01-25 11:05) [7]

Класс TFieldDefs.
Метод Update.
Свойство TFieldDef


 
Arrows   (2005-01-25 11:27) [8]

Непонял!?
Как получить точную структуру dbf в тексте программы?


 
Reindeer Moss Eater ©   (2005-01-25 11:34) [9]

with TQuery.Create(nil) do
try
 DatabaseName := ....
 SQL.Text:= select * from tablename";
 FieldDefs.Update;
 for i:=0 to Pred(FieldDefs.Count) do
  begin
   MyFieldDef := FieldDefs.Items[i];
   if MyFieldDef.DataType = ftString then ShowMessage(...)
    else ...
   ...
   ...
  end;
finally
 Free;
end;


 
Arrows   (2005-01-25 11:47) [10]

Пишу:
k - размерность поля
For i:=0 to dbf1.FieldCount-1 do
begin
If (Form1.dbf1.Fields[i].DataType = ftString)then
 k:=Dbf1.Fields[i].Size;
If (Form1.dbf1.Fields[i].DataType = ftFloat)or  (Form1.dbf1.Fields [i].DataType = ftInteger)then  
 k:= ...?????  
end;


 
Reindeer Moss Eater ©   (2005-01-25 11:49) [11]

Я ж тебе русским языком сказал, что для ftFloat определять размерность бесполезно.


 
Reindeer Moss Eater ©   (2005-01-25 11:50) [12]

и ftInteger - то же.


 
HSolo ©   (2005-01-25 12:06) [13]

Если работаете ч/з BDE, то DbiGetFieldDescs


 
Arrows   (2005-01-25 13:01) [14]

Спасибо всем за дискуссию. Разобрался.
Если кому интересно: Все данные есть в шапке dbf отуда и надо брать данные.


 
Arrows   (2005-01-25 13:02) [15]

Спасибо всем за дискуссию. Разобрался.
Если кому интересно: Все данные есть в шапке dbf отуда и надо брать данные.



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

Текущий архив: 2005.02.20;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.039 c
1-1107778346
-= Demon =-
2005-02-07 15:12
2005.02.20
Как определить, что файл записан на диск полностью


3-1106489170
Mamed
2005-01-23 17:06
2005.02.20
TQRCompositeReport


14-1107022583
xman
2005-01-29 21:16
2005.02.20
EXP


1-1107263086
BaDeVlad
2005-02-01 16:04
2005.02.20
Несворачиваемое окно


14-1107207759
Logun
2005-02-01 00:42
2005.02.20
ВАС ИЗ ДАС .NET