AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi ZEOS TZSqlProcessor verarbeitet MetaScript nicht komplett
Thema durchsuchen
Ansicht
Themen-Optionen

ZEOS TZSqlProcessor verarbeitet MetaScript nicht komplett

Ein Thema von Satty67 · begonnen am 27. Jun 2009 · letzter Beitrag vom 28. Jun 2009
Antwort Antwort
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#1

ZEOS TZSqlProcessor verarbeitet MetaScript nicht komplett

  Alt 27. Jun 2009, 21:17
Datenbank: FireBird • Version: 2.x • Zugriff über: ZeosLib 6.6.5
Hallo,

z.Z. versuche ich die (FireBird) Datenbank-Tabellen, Trigger und CO. automatisch per MetaScript zu erstellen. Dazu verwende ich von Zeos den TZSqlProcessor.
Delphi-Quellcode:
function RunScript(AOwner : TComponent; Connection : TZConnection; Script : TStringList): String;
var
  SqlProcessor : TZSqlProcessor;
begin
  Result := '';
  SqlProcessor := TZSqlProcessor.Create(aOwner);
  try
    SqlProcessor.Connection := Connection;
    SqlProcessor.DelimiterType := dtSetTerm;
    SqlProcessor.Script.Assign(Script);
    try
      SqlProcessor.Execute;
    except
       on E:Exception do Result := E.Message;
    end;
  finally
    SqlProcessor.Free;
  end;
end;
Jetzt werden immer nur drei SQL Anweisungsblöcke abgearbeitet, beim 4. Anweisungsblock bricht TZSqlProcessor ab mit
Code:
SQL Error: Dynamic SQL Error SQL error code = -901 invalid transaction handle (expecting explicit transaction start). Error Code: -901. Unsuccessful execution caused by system error that does not preclude successful execution of subsequent statements The SQL: <Code der 4. SQL-Anweisung>
Die jeweilige SQL-Anweisung scheint irrelevant, da Umsortieren immer die Exception beim 4. Block auslöst (lege mein Test-Script trotzdem mal in die Anlage). TZSqlProcessor.Parse und anschließende Abfrage von Count gibt die korrekte Anzahl der Anweisungs-Blöcke wieder.

Ich bin mit dem Fehler etwas überfordert... scheinbar wird das Transaktions-Handle nach dem 3. Block geschlossen und führt dann beim 4. zum Fehler?

Die Tabellen lassen sich problemlos "einzeln" anlegen, also wenn ich für jede Tabelle und für jeden Trigger einen einzelnen Aufruf starte. Aber das kann ja nicht die Lösung sein...
Angehängte Dateien
Dateityp: txt database.meta.sql_197.txt (778 Bytes, 20x aufgerufen)
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#2

Re: ZEOS TZSqlProcessor verarbeitet MetaScript nicht komplet

  Alt 27. Jun 2009, 23:57
Guten Abend

Ich hab zwar noch nicht mit dem SQLProcessor gearbeitet aber du hast nach der 3. Anweisung ein Commit stehen.

- vieleicht läuft alles in einer Transaktion ?
- durch das Commit schließt du ab und deine 4. Anweisung hat keine Transaktion
- muß das Commit da sein ?

...nur so als schnelle Ideen

[edit]
das mit dem Commit sollte eigentlich so sein. Wenn die Tabellen nicht committed sind kannst du keine Generatoren etc. anlegen oder ?
[/edit]
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#3

Re: ZEOS TZSqlProcessor verarbeitet MetaScript nicht komplet

  Alt 28. Jun 2009, 06:28
Danke, denke das war der richtige Ansatz.

Commit Work scheint den Fehler zu verursachen, also die Transaktion zu beenden, womit das Script dann wohl in einer Transaktion ablaufen soll.

€: Jetzt kommt der Fehler, das "Set Term" unbekannt ist. Das ist offensichtlich eine Fehlermeldung des Parsers. Wenn ich das jetzt richtig überblicke, dann kann SQLProcessor nur mit einem Terminator umgehen und diesen auch nicht innerhalb des Script umschalten.

Entweder bin ich noch nicht reif für SQL oder Zeos ist nicht ausgereift. Ich gebe auf und parse das MetaScript selbst. Ist nicht so schwer, nur Delimiter beachten und per Query einzeln abschicken.
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#4

Re: ZEOS TZSqlProcessor verarbeitet MetaScript nicht komplet

  Alt 28. Jun 2009, 20:41
So, hier meine vorübergehende Lösung des Problems, dass TZSqlProcessor "SET TERM" nicht richtig ausgewertet hat (obwohl es das mit mtSetTerm sollt).

Das ganze noch als Function. Packe das am Ende des Projektes noch in eine Klasse und baue ein Rollback ein (wenn Zeos das zulässt)
Delphi-Quellcode:
uses
  SysUtils, Classes, ZConnection, ZDataSet;

// Execute a MetaScript (e.g. from FlameRobin)
// Result is empty if no error else contains the TZQuery exception message
function ExecuteMetaScript(AOwner : TComponent; Connection : TZConnection; Script : TStringList): String;

  function TermChanged(Sql : String; var Term : Char): Boolean;
  var
    Part : String;
  begin
    Result := False;
    Part := UpperCase(Trim(Sql));
    if Pos('SET', Part) = 1 then begin
      Part := Trim(Copy(Part, 4, 1024));
      if Pos('TERM', Part) = 1 then begin
        Part := Trim(Copy(Part, 5, 1024));
        if Part <> 'then begin
          Term := Part[1];
          Result := True;
        end;
      end;
    end;
  end;

const
  SqlTerm : Char = ';';
var
  i : Integer;
  Term : Char;
  Query : TZQuery;
begin
  Result := '';
  Term := SqlTerm;
  Query := TZQuery.Create(AOwner);
  try
    Query.Connection := Connection;
    for i := 0 to Script.Count - 1 do begin
      // SET TERM prüfen und gleichzeitig ausklammern
      if not TermChanged(Script[i], Term) then begin
        if Term <> SqlTerm then
          Query.SQL.Add(StringReplace(Script[i], Term, SqlTerm, [rfReplaceAll]))
        else
          Query.SQL.Add(Script[i]);
        if Pos(Term, Script[i]) > 0 then begin
          try
            Query.ExecSQL;
          except
            on E: Exception do Result := E.Message;
          end;
          Query.SQL.Clear;
        end;
      end;
    end;
  finally
    Query.Free;
  end;
end;
Ein relativ komplexes MetaScript mit Triggern von FlameRobin wurde sauber verarbeitet.

Falls jemand einen Fehler sieht, bitte mitteilen, korrigiere das dann spätestens beim Anlegen der Klasse.

Wenn jemand ein funktionierenden Code hat, der FlameRobin-MetaScripte (oder vergleichbare) mit "SET TERM" (Trigger, Procedures) via TZSqlProcessor verarbeiten kann, auch her damit
  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 16:24 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