AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

ADO Exception

Ein Thema von jangbu · begonnen am 1. Sep 2009 · letzter Beitrag vom 3. Sep 2009
Antwort Antwort
jangbu

Registriert seit: 6. Apr 2006
171 Beiträge
 
Delphi 10.3 Rio
 
#1

ADO Exception

  Alt 1. Sep 2009, 12:43
Datenbank: SQL Server 2000 • Zugriff über: ADO
Hallo,

steige gerade von BDE auf ADO um. Habe dazu Query durch ADOQuery ersetzt. Läuft auch alles. Nur wie fange ich jetzt (mit ADO) die Fehler z.B. doppelter Schlüssel ab? Der u.g. Mechanismus beruhte auf BDE.

try
Query1.Close;
Query1.SQL.Clear;
Query1.SQL.Add('select * from TABLE');
Query1.Open;
Query1.Append;
Query1.FieldByName('nr').AsInteger := nr;
Query1.Post;
except
on E: EDBEngineError do
if E.Errors[0].ErrorCode = 9729 then Begin
MessageDlg('Fehler bei Insert (duplicate key)! ' + IntToStr(e.errors[0].errorcode) , mtError, [mbOK], 0);
Query1.Cancel;
end
else
MessageDlg('Fehler bei Insert! ' + IntToStr(e.errors[0].errorcode) , mtError, [mbOK], 0);
end;

jangbu
  Mit Zitat antworten Zitat
jangbu

Registriert seit: 6. Apr 2006
171 Beiträge
 
Delphi 10.3 Rio
 
#2

Re: ADO Exception

  Alt 2. Sep 2009, 15:58
Hat da wirklich keine eine Idee?

jangbu
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.537 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: ADO Exception

  Alt 2. Sep 2009, 16:02
Wieso diese Unterscheidung? Lass doch einfach die ErrorMessage der Exception ausgeben, die ist hoffentlich auch aussagefähig.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
jangbu

Registriert seit: 6. Apr 2006
171 Beiträge
 
Delphi 10.3 Rio
 
#4

Re: ADO Exception

  Alt 3. Sep 2009, 08:19
DeddyH,

ich habe versucht einen Datensatz einzufügen der auf einen doppelten Schlüssel Fehler läuft. Ich bekomme leider nur eine allgemeine Fehlermeldung zurück. mtError ist leer?! Mit der BDE bekam ich die Fehlernummer 9729 -> duplicate key. Warum steht in mtError nichts drin?

jangbu
Miniaturansicht angehängter Grafiken
duplicate_key_416.jpg  
  Mit Zitat antworten Zitat
Brainshock

Registriert seit: 26. Nov 2004
Ort: 37345
214 Beiträge
 
Delphi 7 Professional
 
#5

Re: ADO Exception

  Alt 3. Sep 2009, 09:08
Hi,

ist der normale Fehlertext nicht aussagekräftig genug, dass du das nochmal extra abfängst?
Was kommt denn für eine Exceptionklasse zurück? Vielleicht die auswerten bzw. die Message der Exception.

Delphi-Quellcode:
      
try
  Query1.Close;
  Query1.SQL.Clear;
  Query1.SQL.Add('select * from TABLE');
  Query1.Open;
  Query1.Append;
  Query1.FieldByName('nr').AsInteger := nr;
  Query1.Post;
except
  on E: Exception do
    MessageDlg(E.Classname + ' ' + E.Message , mtError, [mbOK], 0);
  Query1.Cancel;
end;
Gruß
Matthias
Matthias
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.537 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: ADO Exception

  Alt 3. Sep 2009, 09:12
Zitat von DeddyH:
Lass doch einfach die ErrorMessage der Exception ausgeben
Damit war E.Message gemeint
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
jangbu

Registriert seit: 6. Apr 2006
171 Beiträge
 
Delphi 10.3 Rio
 
#7

Re: ADO Exception

  Alt 3. Sep 2009, 12:02
Danke,

das war's. E.Message enthält eindeutige Info!

jangbu
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: ADO Exception

  Alt 3. Sep 2009, 12:28
Hallo,

oder du benutzt EADOError statt EDBEngineError.


Heiko
Heiko
  Mit Zitat antworten Zitat
Antwort Antwort


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 07: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