AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Anwendung löschen Daten in Datenbank
Thema durchsuchen
Ansicht
Themen-Optionen

Anwendung löschen Daten in Datenbank

Ein Thema von gmc616 · begonnen am 13. Sep 2007 · letzter Beitrag vom 21. Sep 2007
Antwort Antwort
Seite 1 von 2  1 2      
gmc616

Registriert seit: 25. Jun 2004
Ort: Jena
627 Beiträge
 
Delphi 10.3 Rio
 
#1

Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 12:18
Hallo DP,

Ich stehe vor einem riesen Problem.
Ich habe für eine kleine Firma ein Tool geschrieben (in D7), welchen Daten aus einer dBase-Clipper Datenbank auswerten kann.
Dafür für benutze ich den ADS LocalServer 7.x.
Die eigentliche Haupt-Anwendung der dBase-DBF ist ein DOS-Programm (mehr als 10 Jahre alt).
Das ganze läuft auf einem WinXP/SP2 Rechner. Mein Prog als Windows-Anwendung und das DOS-Prog in/auf der Console.

Das "angebliche" Problem, welches heute seit ca. 2 Jahren das dritte mal aufgetreten ist (mein Prog ist täglich im Einsatz):
Sobald mein Prog geschlossen wird, werden willkürlich Daten in der Datenbank überschrieben.
"Natürlich" ist mein Programm schuld.

Nun das eigenartige: Es werden nur einzelne Felder in den DBF-Dateien mit 0.0 überschrieben, in Tabellen die mein Programm überhaupt nicht angreift, aber im Augenblick des Beendens, in der DOS-Hauptanwendung geöffnet sind.

Ich schicke keine Nachrichten an das DOS-Prog.
Beim Beenden meines Prog wird lediglich eine DLL entladen, die ADSConnection getrennt, 2 eigene Klassen (ohne ADS) freigeben und das Mutex-Handle geschlossen.

Könnt ihr euch eine Konstellation vorstellen, wie so etwas passieren kann?
Kann es sein, dass mein Prog irgendwie den Speicher des DOS-Progs überschreibt?
Laufen DOS-Progs nicht sowieso in einem eigenen geschützten Speicherbereich?
Wie stehen die Chancen, dass tatsächlich mein Programm diesen Mist baut?
Könnte es sein, das ADS irgendwo einen Bug hat? Wisst ihr was? ... oder evtl. WinXP bezüglich dBase??

Reproduzieren lässt sich der Fehler natürlich nicht. (wäre ja zu schön)

Bittend um Hilfe und verzweifelte Grüße

gmc
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 14:03
Zitat von gmc616:
Ich habe für eine kleine Firma ein Tool geschrieben (in D7), welchen Daten aus einer dBase-Clipper Datenbank auswerten kann.
Bedeutet das, dass dein Programm grundsätzlich nur lesend zugreift ??
Falls ja, gäbe es eine einfache Möglichkeit:
Die Tabellen müssen in einem NTFS-Verzeichnis liegen und der Benutzer darf keine Schreibrechte haben.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von RavenIV
RavenIV

Registriert seit: 12. Jan 2005
Ort: Waldshut-Tiengen
2.875 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 14:05
Also ich stelle hier mal eine These auf.

Vermutlich kommt das DOS-Programm durcheinander, wenn Dein Programm die Verbindung zur DB schliesst.
Dann werden vom DOS-Programm die Felder auf 0.0 (Initialwert) gesetzt.

Zu Deinen Fragen:
Es kann nicht sein, dass Dein Programm den Speicher des DOS-Programms überschreibt.
Dein Programm macht den Mist nicht, ist aber vermutlich der Auslöser dafür (s.o.).

Bei ADO gibt es doch sicher auch einen Logger, der alles protokoliert, was zur DB geschickt wird.
Somit kann man dann herausfinden, welches Stück Software dafür verantwortlich ist.
Klaus E.
Linux - das längste Text-Adventure aller Zeiten...
Wer nie Linux mit dem vi konfiguriert hat, der hat am Leben vorbei geklickt.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.196 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 15:28
Wer halt immer noch mit solchen mittlerweilen fragilen DB's arbeitet.

Was spricht dagegen das du die DB physikalisch kopierst und dann mit der Kopier arbeitest. Dann kannst du definitiv nichts mehr verschulden.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
s-off
(Gast)

n/a Beiträge
 
#5

Re: Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 15:37
Zitat von Bernhard Geyer:
Wer halt immer noch mit solchen mittlerweilen fragilen DB's arbeitet.
Ich kann das gut nachvollziehen.
Es gibt halt Anwendungen (welche zugegebenermaßen recht speziell sind), die sich in ihrem Bereich bewährt haben, und zu denen es bis heute keine Alternativen, welche 'modernere' Datenbanksysteme einsetzen, gibt. Zumindest keine Alternative, die mit der bewährten Lösung konkurrieren könnte.

Und die Kundschaft trennt sich nur ungern von Bewährtem.
  Mit Zitat antworten Zitat
Benutzerbild von borncrush
borncrush

Registriert seit: 18. Dez 2005
Ort: Berlin
115 Beiträge
 
Delphi XE7 Enterprise
 
#6

Re: Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 15:46
Hiho,

nur mal eine kurze Zwischenfrage.
Wird hier zufällig mit der "TES"-Software gearbeitet?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.196 Beiträge
 
Delphi 10.4 Sydney
 
#7

Re: Anwendung löschen Daten in Datenbank

  Alt 13. Sep 2007, 16:06
Zitat von s-off:
Es gibt halt Anwendungen (welche zugegebenermaßen recht speziell sind), die sich in ihrem Bereich bewährt haben, und zu denen es bis heute keine Alternativen, welche 'modernere' Datenbanksysteme einsetzen, gibt. Zumindest keine Alternative, die mit der bewährten Lösung konkurrieren könnte.
Dann sollte man aber nicht alles mögliche "Ranhängen" bzw. als Entwickler entsprechende Vorkehrungen treffen (hier: Kopieren der DB) um nicht dann alls Löser für alle Problemfälle herhalten zu müssen (Seit ihrer neuen SW geht das und das nicht mehr - auch wenn mittels Windows-Updates das halbe Betriebssystem ausgetausch wurde).
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
gmc616

Registriert seit: 25. Jun 2004
Ort: Jena
627 Beiträge
 
Delphi 10.3 Rio
 
#8

Re: Anwendung löschen Daten in Datenbank

  Alt 14. Sep 2007, 14:06
Zitat von shima:
Bedeutet das, dass dein Programm grundsätzlich nur lesend zugreift ??
Nein. Es werden u.U. Datensätze upgedated. Aber wie schon gesagt, ihn anderen Tabellen.

Zitat von shmia:
Die Tabellen müssen in einem NTFS-Verzeichnis liegen und der Benutzer darf keine Schreibrechte haben.
Das geht nicht, da die DOS-Anwendung schreibend zugreifen können muss.

Zitat von RavenIV:
Bei ADO gibt es doch sicher auch einen Logger, der alles protokoliert, was zur DB geschickt wird.
ADO habe ich probiert. Allerdings kann ADO nicht mit den Clipper Index-Dateien (*.CDX) umgehen, was aber dringend benötigt wird.
ADS ist die einzigste Komponente, die ich (damals) gefunden habe, die das kann/konnte.

Zitat von Bernhard Geyer:
Wer halt immer noch mit solchen mittlerweilen fragilen DB's arbeitet.
Kann ich leider nix dran ändern. Siehe Antwort von s-off

Zitat von Bernhard Geyer:
Was spricht dagegen das du die DB physikalisch kopierst und dann mit der Kopier arbeitest. Dann kannst du definitiv nichts mehr verschulden.
1,5 GigaByte an Daten
und Änderungen die mit dem DOS-Prog gemacht wurden müssen sofort im meinen Tool verarbeitet werden können
und Rechner + OS aus dem letzten Jahr Tausend.

Zitat von borncrush:
Wird hier zufällig mit der "TES"-Software gearbeitet?
Nein. Mit Veridis. TES kenne ich nicht.

Danke euch für das Kopfzerbrechen

gmc
  Mit Zitat antworten Zitat
HeiztecSupport

Registriert seit: 14. Sep 2007
1 Beiträge
 
#9

Re: Anwendung löschen Daten in Datenbank

  Alt 14. Sep 2007, 14:23
Hallo,

schreibende Zugriffe mit zwei verschiedenen ADS-Versionen oder/und DOS-Treiber und ADS-Treiber (DBFCDX) erzeugen zum Teil inkompatible Indizes.
Schreiboperationen können bei defekten Indizierungen zu ungewünschten Nebeneffekten führen. Dieses Phänomen konnten wir schon mehrfach beobachten.
Insbesondere in Multiuser-Environments wo das unterschiedliche Lockingverhalten der jeweiligen Treiber zu Schreibkollisionen führen kann.
ByteZero wird unterschiedlich benutzt.

Und noch etwas: der Name der unserer Software lautet HEIZTEC/2 und nicht Veridis...

Grüße
HeiztecSupport
Wir setzen Standards
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.196 Beiträge
 
Delphi 10.4 Sydney
 
#10

Re: Anwendung löschen Daten in Datenbank

  Alt 14. Sep 2007, 14:50
Zitat von gmc616:
Zitat von Bernhard Geyer:
Was spricht dagegen das du die DB physikalisch kopierst und dann mit der Kopier arbeitest. Dann kannst du definitiv nichts mehr verschulden.
1,5 GigaByte an Daten
Dann solltest du froh sein das du nicht wöchentlich zerschossene Tabellen mit Datenverlust hast.
Ansonsten Tipps von HeiztecSupport verwenden und das tägliche Stoßgebet bringen das nicht irgendein Windows-Update die Sache irgendwann mal komplett lahm legt.
Windows Vista - Eine neue Erfahrung in Fehlern.
  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 02:56 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