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

Вниз

Неверное число записей в Access   Найти похожие ветки 

 
Algol   (2004-07-15 13:48) [0]

В процедуре происходит присоединение к Access через COM.
При чтении таблицы все замечательно, НО Table.RecordCount выдает количество записей на единицу меньше, чем фактическое число записей. В чем может быть проблема?

uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, Grids, StdCtrls, Buttons, Menus, ExtCtrls ,ComObj, AccessXP, OleServer;
...
Acc:=CoAccessApplication.Create;
Acc.OpenCurrentDatabase(FileName,Empty,Empty);
Table:=Acc.CurrentDb.OpenTable(DefTableName,Empty);
i:=Table.RecordCount;//здесь i на единицу меньше, чем нужно


 
bushmen ©   (2004-07-15 13:54) [1]

А если сначала встать на последнюю запись в таблице, а уже потом вывести количество записей?


 
Algol   (2004-07-15 17:10) [2]

Тот же эффект ...


 
Digitman ©   (2004-07-16 08:55) [3]


> Algol


попробуй доступ к объектам базы не через Access.Application, а непосредственно через DAO.DBEngine


 
Algol   (2004-07-16 11:43) [4]

В общем, побороть не удалось. Баг какой-то ... Толи в COM, то ли в Эксесе.

Пришлось писать функцию:

   function GetRecCount:Integer;
   begin
   result:=0;
   Table.MoveFirst;
   While not Table.eof do
     begin
     inc(result);
     Table.MoveNext;
     end;
   end;


Тупо, но работает :))



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

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

Наверх




Память: 0.47 MB
Время: 0.025 c
1-1090488913
Morg
2004-07-22 13:35
2004.08.08
Увеличение скорости поиска в TStringList


3-1089699015
Fishka
2004-07-13 10:10
2004.08.08
ADOQuery1.SaveToFile - как этим пользоваться?


14-1090704176
Саша
2004-07-25 01:22
2004.08.08
Библия Delphi


3-1089907596
carmen
2004-07-15 20:06
2004.08.08
Как переменую типа Дата разложить на день, месяц и год


14-1089639086
Piter
2004-07-12 17:31
2004.08.08
Создание форм в MDI приложении