AGB  ·  Datenschutz  ·  Impressum  







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

Text mit ''' und variablen Inhalt

Ein Thema von Kostas · begonnen am 11. Aug 2025 · letzter Beitrag vom 11. Aug 2025
Antwort Antwort
Kostas

Registriert seit: 14. Mai 2003
Ort: Gerstrhofen
1.117 Beiträge
 
Delphi 12 Athens
 
#1

Text mit ''' und variablen Inhalt

  Alt Heute, 16:29
Hallo Zusammen,

ab D12 gibt es die Möglichkeit Literale mit 3 Anführungszeichen mehrzeilig zu setzen.
Nur als Beispiel:
Delphi-Quellcode:
x := '''
Select *
From adress
Where x=
'Test'
'''
Gibt es auch eine Möglichkeit das 'Test' variable ist in etwa so:
Delphi-Quellcode:
y := 'Test';
  x := '''
Select *
From adress
Where x=
''+ y +''
'''
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.574 Beiträge
 
Delphi 12 Athens
 
#2

AW: Text mit ''' und variablen Inhalt

  Alt Heute, 16:56
Der erste String fängt mit ''' an, also endet er auch mit '''
und der Zweite muß natürlich auch mit einer ungeraden Anzahl beginnen, so wie er endet.

Delphi-Quellcode:
y := 'Test';
x := '''
Select *
From adress
Where x=
''' + y + '''
''';
oder
Delphi-Quellcode:
y := 'Test';
x := '''
Select *
From adress
Where x=:y
'''.Replace(':y', y);
Aber ganz im Ernst.
SOWAS MACHT MAN NICHT

Wenn SQL, dann NIEMALS Parameter im Code zusammenbauen/ersetzen,
sondern SQL-Parameter nutzen und Y in der SQL-Komponente setzen/zuweisen.

Code-Injection
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (Heute um 17:01 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.772 Beiträge
 
Delphi 12 Athens
 
#3

AW: Text mit ''' und variablen Inhalt

  Alt Heute, 17:08
Das funktioniert nicht! Ein mehrzeiliger String-Literal muss das schließende Symbol am Beginn einer neuen Zeile haben. Damit wird nämlich die Einrückung der Zeilen des Literals festgelegt.
Code:
  y := 'Test';
  x := '''
    Select *
      From adress
    Where x=
    ''' + y;
führt zu diesem Ergebnis:
SQL-Code:
Select *
  From adress
Where x=Test
Variablen innerhalb des Multiline-Literals funktionieren nur über Platzhalter für Format .
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
skybibo

Registriert seit: 23. Jun 2008
Ort: NRW
29 Beiträge
 
Delphi 12 Athens
 
#4

AW: Text mit ''' und variablen Inhalt

  Alt Heute, 17:21
Also mit format wie folgt:

Delphi-Quellcode:
y := 'Test';
x := format('''
Select *
From adress
Where x=%s
''',[y]);
Wenn dahinter noch was kommen würde, dann macht das durchaus Sinn.

Also wie folgt:

Delphi-Quellcode:
y := 'Test';
z := 'Test2';
x := format('''
Select *
From adress
Where (x=%s) or (x=%s)
''',[y,z]);
Ergibt dann:
Code:
Select *
From adress
Where (x=Test) or (x=Test2)
Bernd
  Mit Zitat antworten Zitat
Kostas

Registriert seit: 14. Mai 2003
Ort: Gerstrhofen
1.117 Beiträge
 
Delphi 12 Athens
 
#5

AW: Text mit ''' und variablen Inhalt

  Alt Heute, 20:51
Ich benötige kein SQL, das war nur ein Beispiel zum besseren Verständnis. Die Idee mit dem Format ist für meinen Fall die beste Lösung, vielen Dank für den Hinweis. Ich dachte nur, möglicherweise muss man ein bestimmtes Zeichen zum escapen verwenden.
  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 21:56 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