HyperLink
Bejelentkezés
E-mail: 
Jelszó: 





Skip Navigation Links
 

Adatbázis hibák kezelése


Példaprogram letöltése

4035 bájt

Amikor egy adatbázis-kezelő alkalmazást készítünk, fontos és elkerülhetetlen feladat, hogy kezeljük az esetlegesen felvetődő adatbázis hibákat. Ebben a példában azt vizsgáljuk, hogy erre a Delphi milyen lehetőségeket biztosít számunkra.

Az adatbázis hibák forrása sokféle lehet. Ha nem kezeljük megfelelően a felmerülő hibákat, akkor a Delphi és a BDE üzeneteit láthatjuk, ami nem szép megoldás egy magyar nyelvű programban, ráadásul beláthatatlan, hogy a hibaüzenet után alkalmazásunk miként fog működni.
Ha mi akarjuk kezelni a hibákat, 3 fajta lehetőség kínálkozik.
  • A legegyszerűbb, ha a kritikus algoritmusokat try-except blokkokban helyezzük el. Ez a megoldás eléggé egyszerű, de nem alkalmazható minden esetben. Nem használhatjuk például akkor, ha adatfüggő kontrolokat használunk.
  • Egy másik megoldás, ha felhasználjuk az adathozzáférést biztosító komponensek hibakezelő eseményeit. Pl.: OnDeleteError, OnEditError, OnPostError, stb.
  • Létrehozhatunk egy globális ApplicationEvents objektumot is, melynek az OnException eseményén keresztül kezelhetjük az egyes hibákat.
A mellékelt példaprogramban mindhárom megoldásra található példa.
Ha az adatforrás hibakezelő eseményeit használjuk, akkor az eseménykezelő eljárásban kapunk egy paramétert, melynek típusa EDatabaseError.
procedure Table1DeleteError(DataSet: TDataSet; E: EDatabaseError; var Action: TDataAction);
Az EDatabaseError osztály, Message tagjából kiolvashatjuk a hibaüzenetet.
Az Action paraméter határozza meg, hogy mi történjen a hiba kezelése után. A daFail esetén a rendszer ad hibaüzenetet. daAbort esetén a hibaüzenet nem jelenik meg. A daRetry megpróbálja megismételni a műveletet. Ezt akkor használjuk, ha sikerült megszüntetnünk a hiba okát.
Ha a harmadik megoldást választjuk, akkor az OnException esemény E paraméteréből értesülhetünk a hibáról.
procedure ApplicationEvents1Exception(Sender: TObject; E: Exception);
Ebben az esetben, az adatbázis hibák kezeléséért a EDBEngineError osztály a felelős. Az osztály egyszerre több hibaüzenetet is tárolhat, melyek kezeléséhez két property áll rendelkezésünkre.
ErrorCount
property ErrorCount: Integer;
Az Errors property-ben található hibák számát adja meg.
Errors
property Errors[Index: Integer]: TDBError;
Egy tömb, amely a hibákat tartalmazza.
Az Errors property minden egyes eleme TDBError típusú, melynek a következő tulajdonságai vannak:
Category
Osztály: TDBError
property Category: Byte;
A BDE hibakód felső bájtja.
ErrorCode
Osztály: TDBError
property ErrorCode: DBIResult;
BDE hibakód.
Message
Osztály: TDBError
property Message: String;
Az ErrorCode-ban található hibakódhoz tartozó hibaüzenet.
NativeError
Osztály: TDBError
property NativeError: Longint;
Segítségével megállapíthatjuk, hogy a hiba a szerverről jött-e. Ha értéke 0, akkor a hiba nem a szerverről jött.
SubCode
Osztály: TDBError
property SubCode: Byte;
A BDE hibakód alsó bájtja.

Cikksorozat

#IDKategóriaCikk címeSorozat
2591WindowsTippek és trükkök - RAS - Modem csengetési szám állítása1. rész
2622WindowsTippek és trükkök - Program futtatása más felhasználóként2. rész
2640WindowsA Windows ikonméretének megváltoztatása és Windows 2000 Asztaltémák3. rész
2657WindowsTippek és trükkök - Internet Explorer4. rész
2667WindowsTippek és trükkök5. rész
2684WindowsAlapértelmezések állítása, telepítési fájlok helye, intéző nézetek6. rész
2696WindowsBiztonsági trükkök7. rész
2702WindowsWindows XP trükkök8. rész
2729WindowsWindows 2000 és XP tippek, trükkök9. rész
2757WindowsRegistry trükkök10. rész
2784WindowsTippek, trükkök11. rész
2829WindowsTippek, trükkök12. rész
2889WindowsWindows XP tippek13. rész
2909WindowsTippek Windows XP-hez14. rész
2919WindowsWindows tippek15. rész
2924WindowsWindows tippek16. rész
2963WindowsWindows tippek17. rész
2973WindowsWindows Tippek18. rész
2981WindowsWindows tippek19. rész
2990WindowsTippek-trükkök20. rész
3027WindowsIIS tippek21. rész
3034WindowsWindows XP tippek-trükkök22. rész
3088WindowsWindows 2000/XP tippek, trükkök23. rész
3133WindowsWindows XP tippcsokor24. rész
3140WindowsWindows XP tippek, trükkök25. rész
3152WindowsXP és IIS tippek - trükkök26. rész
3158WindowsWindows XP tippek, trükkök27. rész
3168WindowsTippek, trükkök28. rész
3170WindowsRegistry trükkök29. rész
3179WindowsTippek, trükkök30. rész
3197WindowsWindows XP tippek, trükkök31. rész
3205WindowsTippek, trükkök32. rész
3214WindowsTippek, trükkök33. rész
3223WindowsTippek, trükkök34. rész
3233WindowsTippek, trükkök35. rész
3271WindowsTippek, trükkök36. rész
3307WindowsTippek, trükkök37. rész
3370WindowsTippek, trükkök38. rész
3399WindowsTippek, trükkök39. rész
3510WindowsTippek, trükkök40. rész
3611WindowsHardverrel kapcsolatos tippek, trükkök41. rész
3668WindowsRegistry trükkök42. rész
3711WindowsTippek, trükkök43. rész
3771WindowsTippek, trükkök44. rész
3801WindowsTippek, trükkök45. rész
3831WindowsTippek, trükkök46. rész
3891WindowsTippek, trükkök47. rész
3921WindowsTippek, trükkök48. rész
3981WindowsTippek, trükkök49. rész
4041WindowsTippek, trükkök50. rész
4071WindowsTippek, trükkök51. rész
4151WindowsTippek, trükkök52. rész
4171C#Tippek, trükkök53. rész
4211WindowsTippek, trükkök54. rész
4251WindowsTippek, trükkök55. rész
4281WindowsTippek, trükkök56. rész
3589DelphiTippek, trükkök57. rész
3718DelphiTippek, trükkök58. rész


Könyv
Ez a cikk megtalálható ebben a könyvben: Delphi Software Offline 2003 évkönyv 369. oldal

Felhasználási feltételek
A Software Online szoftverfejlesztői magazin mindegyik cikke, minden megjelent képe, és egyéb publikált anyaga szerzői jog védelme alatt áll! Bármilyen formában történő másodlagos terjesztésük, közzétételük vagy felhasználásuk kizárólag a kiadó előzetes írásbeli engedélyével történhet!

Copyright © 1999-2012 Animare Software Kft. Minden jog fenntartva!
| Készült: Animare Stúdió | Adatvédelem | Kapcsolat |