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

Вниз

Чтение информации из dbf   Найти похожие ветки 

 
ANB ©   (2005-05-19 16:55) [40]


> они дату в строке держат и пустая дата = пустая строка
- ну да, я строки и достаю напрямую из dbf. Кстати, просто читатель не так уж и тяжело пишется. Для ДБФ + МЕМО я писал 3 дня в расслабухе, ну индексы еще можно за 1-6 дней подрубить. Там другое хуже - индексы могут быть разных форматов.


 
Yurisimus   (2005-06-02 09:04) [41]

Я тут натолкнулся на следующий глюк в компоненте TDBF - не могу создать поле типа Float, у него не прописываются Precision и Size, а если без них прописывать, то создается слишком большое число 18 сайз и после запятой 9 знаков, жуть... А мне надо для цены использовать всего лишь float(5,2)... Какие есть нормальные компоненты для работы с *.dbf-ками??? Именно интересует следующие функции:
1) Создание таблицы
2) Создание индексного файла
3) Ну и поддержка хотябы 3 видов полей - string,integer и float
Если кто знает такой компонентик плиз подскажите, а то муторно все это прописывать своими ручками...


 
Anatoly Podgoretsky ©   (2005-06-02 09:19) [42]

Yurisimus   (02.06.05 09:04) [41]
Кто же для денег использует Float :-)
Это надо себя очень не любить.
Float в xBase применяется для очень больших (свыше 18/20 знаков) или малых чисел.
Сам TDbf очень глюкавый компонент, применение оправдано только для простых Embeded систем.


 
Anatoly Podgoretsky ©   (2005-06-02 09:20) [43]

Одна из серьезных проблем это порча таблиц, нарушение стуктуры базы.


 
ANB ©   (2005-06-02 09:26) [44]


> 3) Ну и поддержка хотябы 3 видов полей - string,integer
> и float
таких типов в DBF никогда не было.
Были Char (фиксированная строка), Memo (для длинных строк, но огребаешь проблемы), Number (с фиксированной запятой, хранится в сиде строки) и Date (дата в виде строки). А, еще логическое было. Може чего и пропустил, но флоат и интегер там отсутствовали.
Сомневаюсь, что с такой функциональностью ты найдешь компоненты. Это же получится обычная старая добрая СУБД Fox.


 
Yurisimus   (2005-06-02 09:36) [45]

Анатолию :
Ладно, скажем так - ftCurrency, но и для него не проставляется кол-во знаков после запятой...

ANB : Ну кто же этого не знает, я просто привел как пример общепонятные и общедоступные типы полей, кто знает - поймет...

Здесь также был рассмотрен компонент halcyon, стоит ли вообще тратить на него время или такой же глюкавый как и TDBF???


 
Anatoly Podgoretsky ©   (2005-06-02 09:42) [46]

ANB ©   (02.06.05 09:26) [44]
Тебе не тяжело будет нажать на пробел в колонке Type диалога создания таблицв в Database Desktop?
И нестоит говорить как хранится не представляя сущности.


 
Anatoly Podgoretsky ©   (2005-06-02 09:44) [47]

Yurisimus   (02.06.05 09:36) [45]
FCurrency не поддержан, вместо него есть более мощный тип Number


 
Yurisimus   (2005-06-02 09:50) [48]

Анатолий :
Ну ты все никак не уймешься... :) Для ВСЕХ типов в TDBF невозможно проставить кол-во знаков после запятой...

И все же хотелось бы послушать мнения по теме, то есть запись и чтение данных из DBF, а не слушать препирания друг друга... Есть ли компонент осуществляющий такие функции или все же придется все это прописывать вручную??? :)


 
ANB ©   (2005-06-02 09:51) [49]


> Anatoly Podgoretsky ©   (02.06.05 09:42) [46]
- да чаво там представлять то как хранится. Залез нортоном и посмотрел. Строка там лежит. Нагло для всех полей. Числа тоже строками лежат. Прямо так 1234.50


 
ANB ©   (2005-06-02 09:54) [50]


> Yurisimus   (02.06.05 09:50) [48]
сам писать возмешься ? Дам сырцы по чтению. Запись так себе, но работает без ошибок. Добавление и индексы - делать самому. Создание таблицы - тоже, но это, имхо, не трудно. (Просто грамотно описать заголовок и запихать в файл, структура файла есть) Индексы я сроду не пытался делать - влом было.


 
Anatoly Podgoretsky ©   (2005-06-02 10:01) [51]

ANB ©   (02.06.05 09:51) [49]
Модифицированый BCD формат, а даты в System Date Format SDF


 
Yurisimus   (2005-06-02 10:10) [52]

ANB :
Да я уже в принципе начал, подрубился через ADO, чтобы была возможность выполнять SQL запросы использовал Query. Да и с типом Float разобрался при создании таблицы, правда для этого сначала сбацал файл MS Excel, а уж потом сохранил его как *.dbf... Дальше проще, просто выполнять SQL запросы и все... привожу пример из проги, хотелось бы проще при использовании TDBF, примерно так:
   (прописал функции (GetMyDir и GetMyFile) на разделение пути и файла)
   Dbf1.FilePathFull:=GetMyDir(SaveDialog1.FileName);
   Dbf1.TableName:=GetMyFile(SaveDialog1.FileName);
   Dbf1.FieldDefs.Add("id",ftInteger);
   Dbf1.FieldDefs.Add("name",ftString,100);
   Dbf1.FieldDefs.Add("price",ftCurrency,(5,2)); //вот это поле и не создается...с ftFloat тоже не работает...
   Dbf1.FieldDefs.Add("edizm",ftString);
   Dbf1.FieldDefs.Add("srok",ftString,10);
   Dbf1.FieldDefs.Add("norma",ftInteger);
   Dbf1.FieldDefs.Add("proizvod",ftString,50);
   Dbf1.FieldDefs.Add("firma",ftString,50);
   Dbf1.CreateTable;

А вот через ADO и Excel:

 qrXLTo.Close;
 connXLTo.Close;
 if dlgSaveXL.Execute then
 begin
   {Create XLS File}
   MyExcel:=CreateOleObject("Excel.Application");
   MyExcel.WorkBooks.Add;
   MyExcel.WorkBooks[1].WorkSheets[1].Name:="Analiz";
   MyExcel.Cells[1,1]:="id";
   MyExcel.Cells[1,2]:="name";
   MyExcel.Cells[1,3]:="price";
   MyExcel.Cells[1,4]:="edizm";
   MyExcel.Cells[1,5]:="srok";
   MyExcel.Cells[1,6]:="norma";
   MyExcel.Cells[1,7]:="proizvod";
   MyExcel.Cells[1,8]:="firma";
   MyExcel.Cells[2,1]:="0";
   MyExcel.Cells[2,2]:="abcd";
   MyExcel.Cells[2,3]:=1.23;
   MyExcel.Cells[2,4]:="abcd";
   MyExcel.Cells[2,5]:="abcd";
   MyExcel.Cells[2,6]:="abcd";
   MyExcel.Cells[2,7]:="abcd";
   MyExcel.Cells[2,8]:="abcd";
   ColumnRange:=MyExcel.Workbooks[1].WorkSheets[1].Columns;
   ColumnRange.Columns[1].ColumnWidth:=7;
   ColumnRange.Columns[2].ColumnWidth:=100;
   ColumnRange.Columns[3].ColumnWidth:=10;
   ColumnRange.Columns[4].ColumnWidth:=7;
   ColumnRange.Columns[5].ColumnWidth:=10;
   ColumnRange.Columns[6].ColumnWidth:=7;
   ColumnRange.Columns[7].ColumnWidth:=50;
   ColumnRange.Columns[8].ColumnWidth:=50;
   MyExcel.ActiveWorkbook.SaveAs(dlgSaveXL.FileName+".dbf", 11, false, false, false, false);
   MyExcel.ActiveWorkbook.Close(SaveChanges:=True);

   try
     // Нахожу запущенный экземпляр Excel...
     MyExcel:=GetActiveOleObject("Excel.Application");
     // Удаляю чтобы не висел в задачах...
     MyExcel:=0;
   except
   end;

   Dbf1.FilePathFull:=GetMyDir(dlgSaveXL.FileName);
   Dbf1.TableName:=GetMyFile(dlgSaveXL.FileName)+".dbf";
   Dbf1.Active:=true;
   Dbf1.AddIndex("id_idx","id",[ixPrimary]);

Сами видите что если работать через ADO&Excel то получается много писанины, поентому и хотелось бы компонентик найти чтобы двумя строчками все это забацать...



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

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

Наверх




Память: 0.57 MB
Время: 0.03 c
6-1112684994
lin
2005-04-05 11:09
2005.07.11
TService + TClientSocket + TServerSocket


1-1118397912
Dysan
2005-06-10 14:05
2005.07.11
помогите понять в чем причина возникновения ошибки!


14-1118321100
Тульский
2005-06-09 16:45
2005.07.11
Детям министров позволено всё


14-1118142918
Alexander Panov
2005-06-07 15:15
2005.07.11
Западные ценности. Европейские ценности. Демократия.


1-1119345119
MadGhost
2005-06-21 13:11
2005.07.11
динамическое создание линии...