AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Dependencies für Generatoren ermitteln
Thema durchsuchen
Ansicht
Themen-Optionen

Dependencies für Generatoren ermitteln

Ein Thema von RSE · begonnen am 12. Sep 2013 · letzter Beitrag vom 19. Sep 2013
Antwort Antwort
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#1

AW: Dependencies für Generatoren ermitteln

  Alt 15. Sep 2013, 01:20
Nun möchte ich natürlich vor dem Löschen eines Generators mit
Code:
delete from RDB$GENERATORS where RDB$GENERATOR_NAME = 'MY_GEN';
möglichst sichergehen, dass er nicht mehr benutzt wird.
Dazu reicht es aber bei weitem nicht, nur auf eventuell vorhandene Trigger zu überprüfen. Der Generator kann doch überall gesetzt werden. Z.B. von Hand : SET GENERATOR GEN_X TO 123, in SP usw. Da ist nun in der Tat guter Rat teuer, wie man den übeflüssigen Krempel wieder wegkriegt, ohne Schaden anzurichten. Ich würde mir mal den momentanen Stand de Generatoren ansehen. Stehen da welche auf 0, das wären dann schon mal potentielle Löschkandidaten.

Mal schnell mit Delphi-Mitteln so was gebaut :

Delphi-Quellcode:
procedure TForm1.ZeigeDaten;
var GeneratorWert,
    GeneratorName : string;
begin
  DbDS.Close;
  DbDS.SelectSQL.Text := 'select * from RDB$GENERATORS';
  DbDS.Open;
  DbDS.First;
  re1.Lines.Add('Datenbank : '+Database.DatabaseName);
  while not DbDS.Eof do begin
    GeneratorName := DbDS.FieldByName ('RDB$Generator_name').AsString;
    if Copy (GeneratorName,1,4) = 'GEN_then begin // Systemgeneratoren ausklammern
      DetailDS.Close; // ^^ bei mir fangen sie so an
      DetailDS.SelectSQL.Text := 'SELECT GEN_ID(' + GeneratorName + ', 0) G FROM RDB$DATABASE ';
      DetailDS.Open;
      GeneratorWert := DetailDS.FieldByname ('G').AsString;
      re2.Lines.Add(GeneratorName + blanks (20-length (GeneratorName)) + ' '+ GeneratorWert);
    end;
    DbDS.Next;
  end;
end;
Gruß
Hansa
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.010 Beiträge
 
Delphi 2009 Professional
 
#2

AW: Dependencies für Generatoren ermitteln

  Alt 15. Sep 2013, 10:12
Ich würde mir mal den momentanen Stand de Generatoren ansehen. Stehen da welche auf 0, das wären dann schon mal potentielle Löschkandidaten.
Richtig, man könnte auch durch einen Vergleich zweier Schnappschüsse (über ein diff, z.B. aus TortoiseSVN) alle Generatoren auffinden die sich über einen längeren Zeitraum nicht geändert haben und gezielt prüfen, ob diese durch Wegfall von Code auch nicht mehr angesprochen werden. Alle die sich ändern, kann man auf die "Negativliste" setzen (d.h. diese Generatoren dürfen nicht gelöscht werden).

Mit IBExpert kann man die Metdaten der Datenbank als SQL extrahieren und dabei alle Objekte ausser den Generatorwerten ausfiltern - damit hat man die Werte in einer Textdatei und braucht keinen Code dazu schreiben.
Michael Justin
  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 14:05 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