![]() |
Datenbank: Ads local Server • Version: 7.1 • Zugriff über: TDataSet
Ads Error 7038 Invalid record number?
Hallo,
ich bekomme direkt beim starten der Anwendung folgenden Fehler: Zitat:
Viele Grüße... |
Re: Ads Error 7038 Invalid record number?
Zitat:
|
Re: Ads Error 7038 Invalid record number?
Hi,
sollte es dann ausreichen, wenn ich IndexCollationMismatch auf icmReindex einstelle? Viele Grüße... |
Re: Ads Error 7038 Invalid record number?
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.
|
Re: Ads Error 7038 Invalid record number?
Hallo,
Zitat:
Viele Grüße... |
Re: Ads Error 7038 Invalid record number?
Das kann passieren, wenn der User z.b. ein Backup unvollständig wieder zurückspielt. Dann stimmen die Tabellen nicht mit den Indexdateien überein.
|
Re: Ads Error 7038 Invalid record number?
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:
Allerdings werden die Dateien beim Backup ja komplett ersetzt. Kann es da dann wirklich zu dem Fehler kommen?
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; Viele Grüße... |
Re: Ads Error 7038 Invalid record number?
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; |
Re: Ads Error 7038 Invalid record number?
Hi,
ich verwende ausschließlich die Local-Version. Exceptions werden ebenfalls protokolliert. Was da ankommt sieht so aus: Zitat:
|
Re: Ads Error 7038 Invalid record number?
Dann kann es vielleicht sein, dass (entweder beim Backup oder beim Restore) zwei Instanzen Deines Programms geöffnet waren?
|
Re: Ads Error 7038 Invalid record number?
Hallo,
da werde ich den User wohl nochmal kontaktieren müssen. Ich melde mich dann nochmal. Bisher wird im Programm auf jeden Fall nicht verhindert, dass es sich mehrmals öffnen lässt! Viele Grüße... |
AW: Ads Error 7038 Invalid record number?
Nach 18 Jahren auch von mir: Vielen Dank, das Packen hat die Tabellen wieder repariert.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:39 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz