AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Ads Error 7038 Invalid record number?
Thema durchsuchen
Ansicht
Themen-Optionen

Ads Error 7038 Invalid record number?

Ein Thema von Grolle · begonnen am 10. Jul 2006 · letzter Beitrag vom 19. Jan 2024
Antwort Antwort
Seite 1 von 2  1 2      
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#1

Ads Error 7038 Invalid record number?

  Alt 10. Jul 2006, 20:25
Datenbank: Ads local Server • Version: 7.1 • Zugriff über: TDataSet
Hallo,

ich bekomme direkt beim starten der Anwendung folgenden Fehler:
Zitat:
AdsTable1: Error 7038: Invalid record number
Weiß jemand, was das bedeutet?

Viele Grüße...

  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Ads Error 7038 Invalid record number?

  Alt 10. Jul 2006, 20:30
Zitat von Advantage Database Error Guide:
Problem: Attempted to read a record and the record number is greater than the number of records in the file. This error often results from using an index that contains more keys than the table has records. This can occur if a Pack or Zap is performed on the table when the index file(s) was closed.

Solution: Reposition to a valid record number. Reindex the index(es) that contain more keys than the table has records.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#3

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 07:47
Hi,
sollte es dann ausreichen, wenn ich IndexCollationMismatch auf icmReindex einstelle?
Viele Grüße...

  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#4

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 07:54
Nei, Du musst neu indexieren. Zum Beispiel über sp_packtable. Und künftig musst Du darauf achten, dass Die Indexdateien auch geöffnet sind und damit nicht mehr mit dem Inhalt der Tabelle divergieren.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#5

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 08:05
Hallo,

Zitat:
. Und künftig musst Du darauf achten, dass Die Indexdateien auch geöffnet sind und damit nicht mehr mit dem Inhalt der Tabelle divergieren.
Wie kann ich das erreichen? Das Problem ist bis jetzt noch nie aufgetreten. (Leider auch bei einem User und nicht bei mir selber!)

Viele Grüße...

  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 08:13
Das kann passieren, wenn der User z.b. ein Backup unvollständig wieder zurückspielt. Dann stimmen die Tabellen nicht mit den Indexdateien überein.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#7

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 08:36
Hi,

es ist nur eine Tabelle und eine Indexdatei. Bei einer Sicherung der Daten wird der gesamte Ordner (inklusive *.adi und *.adt)
gespeichert. Dieser wird dann beim Backup zurück kopiert bzw. ersetzt. Sonst passiert mit dem Index nur folgendes:

Delphi-Quellcode:
oncreate:
  ADSTable1.IndexName := 'NAME';

gridclick:
  if (ARow = 0) and (ACol = 1) then ADSTable1.IndexName := 'NAME';
  if (ARow = 0) and (ACol = 2) then ADSTable1.IndexName := 'VORNAME';
  if (ARow = 0) and (ACol = 3) then ADSTable1.IndexName := 'STRASSE';
  if (ARow = 0) and (ACol = 5) then ADSTable1.IndexName := 'PLZ';
  if (ARow = 0) and (ACol = 6) then ADSTable1.IndexName := 'WOHNORT';
  if (ARow = 0) and (ACol = 11) then ADSTable1.IndexName := 'DEFINIERBAR';
  if (ARow = 0) and (ACol = 15) then ADSTable1.IndexName := 'GRUPPE';

Backup zurückspielen:
if (copyfile(PChar(pfad +'\adressen.adi'),PChar((ExtractFilePath(ParamStr(0))+ '\daten\adressen.adi')),false)= true) and
          (copyfile(PChar(pfad +'\adressen.adt'),PChar((ExtractFilePath(ParamStr(0))+ '\daten\adressen.adt')),false)= true) then
        begin
        end else
        begin
          AdsConnection1.IsConnected := true;
          AdsTable1.Active := true;
          Statusbar1.Panels.Items[1].Text := IntToStr(ADSTable1.recordcount);
          MessageDlg(' Fehler bei der Wiederherstellung der Datenbank! ',mtError,[mbOK],0);
        end;
Allerdings werden die Dateien beim Backup ja komplett ersetzt. Kann es da dann wirklich zu dem Fehler kommen?

Viele Grüße...

  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#8

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 08:45
Das ist ja sehr schön. Aber Du protokollierst den Fehler nicht - und wie schnell ist so eine Meldung weggeklickt. Nachher war's natürlich keiner. Und wenn Du mit dem ADS als echter Server-Version arbeitest (nicht die Local-Version), dann werden die Tabellen beim Schliessen der Connection nicht sofort alle geschlossen! Die werden noch eine Weile aus Performancegründen gecached, und zwar die 25 zuletzt benutzten.

Ich verwende dies hier, wenn ich sicher sein will, dass die Tabellen wirklich zu sind:
Delphi-Quellcode:
//------------------------------------------------------------------------
procedure TfrmMain.CloseAllAdsTables;
//------------------------------------------------------------------------
// Alle Tabellen auf jeden Fall schliessen
//------------------------------------------------------------------------
begin
   Ace.AdsCacheopenCursors(0);
   frmData.AdsConnection.CloseCachedTables;
   frmData.AdsConnection.IsConnected := false;
   Ace.AdsCacheopenCursors(25);
end;
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#9

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 08:54
Hi,
ich verwende ausschließlich die Local-Version. Exceptions werden ebenfalls protokolliert. Was da ankommt sieht so aus:
Zitat:
10.07.2006 01:44:34 E/A-Fehler 32 EInOutError ToolBar110.07.2006 01:44:51 E/A-Fehler 32 EInOutError ToolBar110.07.2006 12:05:29 AdsTable1: Error 7038: Invalid record number. EADSDatabaseError Form1
Viele Grüße...

  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#10

Re: Ads Error 7038 Invalid record number?

  Alt 11. Jul 2006, 09:00
Dann kann es vielleicht sein, dass (entweder beim Backup oder beim Restore) zwei Instanzen Deines Programms geöffnet waren?
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:23 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz