![]() |
Datenbank: Oracle • Version: 10g • Zugriff über: SQLDirect
Dynamische SQL in Stored Procedure mit Hochkomma-Problem
Ich will in einer Stored Procedure - mit Execute Immediate - eine temporäre Tabelle anlegen mit Strings in diversen Join-Bedingungen. Theoretisch verstehe ich wie es geht, aber praktisch funktioniert es leider nicht.
Mein SQL-Statement stelle ich in einer VARCHAR2 Variablen zusammen. Vereinfacht sieht es folgendermaßen aus:
SQL-Code:
Ich muss den String verketten, da an der Stelle kein binden möglich ist, habe ich herausgefunden.
lSQL := 'CREATE GLOBAL TEMPORARY TABLE TempData AS ' ||
'SELECT t1.col1, t2.col2 ' || 'FROM tabelle1 t1 JOIN tabelle2 t2 ON (t2.col3 = ''' || value || ''' AND t1.col4 = t2.col4);'; Das verblüffende für mich ist, dass im Resultat um den Wert value jeweils zwei einzelne Hochkomma stehen, also ''wertX'' statt 'wertX', obwohl ich gedacht habe, dass in PL/SQL die einfachen Hochkomma verdoppelt werden müssen, um am Schluss ein Hochkomma stehen zu haben. Weiß jemand wo ich meinen Denkfehler habe? Vielen Dank schon mal für die Hilfe, JoyAnn |
Re: Dynamische SQL in Stored Procedure mit Hochkomma-Problem
Herzlich willkommen in der Delphi-PRAXiS, Carola.
Kann es nicht sein, dass die String Variable value bereits begrenzende Hochkommata enthält? Beim Zusammenbau eines SQL Statements mittels Literalen musst du jede Variable vorbehandeln, damit enthaltene Hochkommata verdoppelt werden. Freundliche Grüße |
Re: Dynamische SQL in Stored Procedure mit Hochkomma-Problem
Hallo Marabu,
danke für den Tipp, ich war überrascht, aber genau das war das Problem. Erkennt das PL/SQL automatisch um was für einen Variablentyp es sich handelt? Also meine Variable enthielt keine Hochkomma, aber irgendwie wurden diese richtig gesetzt entsprechend des verketteten Variablentyps. Wenn ich in Delphi den gleichen String zusammenstellen will, muss ich mich selber um die Hochkommas kümmern, hier anscheinend nicht. Also nochmal vielen Dank. |
Re: Dynamische SQL in Stored Procedure mit Hochkomma-Problem
Hallo,
Verwendung von QuotedStr ist meist die Abhilfe. Heiko |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:55 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