AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Wie größere SQL Statements schreiben?
Thema durchsuchen
Ansicht
Themen-Optionen

Wie größere SQL Statements schreiben?

Ein Thema von divBy0 · begonnen am 18. Nov 2009 · letzter Beitrag vom 18. Nov 2009
Antwort Antwort
Seite 2 von 2     12   
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#11

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 12:39
Zitat von Sharky:
const crlf = #10#13 und für "+ crlf +" ein kleines template.
Seit wann gibt es in Delphi Templates? Übrigens ist CRLF #13#10, nicht umgekehrt.
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.798 Beiträge
 
Delphi 12 Athens
 
#12

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 13:47
Zitat von Sharky:
Dann halt so (pseudo code)
Delphi-Quellcode:
const crlf = #10#13
beging
query.sql.text := 'SELECT * FROM tabelle' + crlf +
                  'WHERE blubb = :blubb AND'  + crlf +
                  'meow = :meow'  + crlf +
                  'ORDER BY wuppdi';

und für "+ crlf +" ein kleines template.
Da find ichs aber so doch schöner:

Delphi-Quellcode:
query.sql.add('SELECT * FROM tabelle');
query.sql.add('WHERE blubb = :blubb AND');
query.sql.add('meow = :meow');
query.sql.add('ORDER BY wuppdi)';
Mein TOAD kann daraus auch sehr einfach den SQL-Befehl "strippen". Aus Deiner Variante vermutlich auch...aber..naja, aber halt.

Sherlock
Oliver
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#13

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 14:06
Zitat von Sherlock:
...Genau das würde ich nicht machen.
Da ich meinen Code stehts teste, macht mir das nichts: Das ist ja ein relativ einfacher Fehler, der sofort auffällt.

Aber:
Wenn ich einen langen SQL-Ausdruck im Code zusammenbasteln würde, dann habe ich ja schon etwas falsch gemacht. Bei längeren SQL-Anweisungen erstelle ich mir dafür im RDMBS eine View, Funktion oder Stored Procedure (je nachdem, was das RDBMS so kann).

Und wenn ich mal frickeln muss/will/darf/kann, dann mache ich das so (mit Leerzeichen am Ende. Das bekommt man schon hin. Von mir aus auch ein crlf oder was weiss ich):
Delphi-Quellcode:
Const
  sqlLongStmt = 'SELECT * FROM SQLTable '
              + 'WHERE Foo = Bar '
              + 'AND Bar = 2';

...
  SQLQuery.Execute (sqlLongStmt);
  ...
  SQLQuery.SQL.Text := sqlLongStmt;
  ...
"Magic Strings im Code sind schlecht".
Ich lass mir meinen Delphi-Code doch nicht durch ellenlange 'Add'-Aufrufe (oder Stringkonstanten, die über mehrere Zeilen gehen) unleserlich machen. Wichtig ist (oben ist ein schlechtes Beispiel), das der Name der Konstanten selbsterklärend ist.
Hier mal ein Vergleich:
Delphi-Quellcode:
SQLQuery.SQL.Clear;
SQLQuery.SQL.Add('SELECT MAX(R.Total) FROM Customer C '+crlf;
SQLQuery.SQL.Add(' JOIN Revenue r ON c.CustomerID = r.CustomerID '+crlf;
SQLQuery.SQL.Add(' WHERE r.DateTime BETWEEN :DateFrom AND :DateTo';
// Befüllen mit Parametern
....
// Oder so
Const
  GetHighestRevenueOfLastFY = 'SELECT MAX(R.Total) FROM Customer C '
                            + 'JOIN Revenue r ON c.CustomerID = r.CustomerID '
                            + 'WHERE r.DateTime BETWEEN :DateFrom AND :DateTo';
....
SQLQuery.SQL.Add := GetHighestRevenueOfLastFY;
// Befüllen mit Parametern
So versteht das auch jemand, der kein SQL kann. Zugegeben, o.g. SQL ist simpel, aber was ist, wenns mal richtig komplex wird? Wie gesagt: Sobald mal ein JOIN drin vorkommt oder der Filter komplexer wird (oder.. oder.. oder), bau ich mir lieber eine VIEW zusammen. Dann packe ich die Query aber trotzdem wie oben gezeigt in eine Konstante, gebe der einen guten Namen und verwende die im Code.

Um also die Frage des Threadstellers zu beantworten ('Wie würde ich ein langes SQL-Statement im Delphi-Code formatieren?'): Gar nicht.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Benutzerbild von divBy0
divBy0

Registriert seit: 4. Mär 2007
Ort: Sponheim
1.021 Beiträge
 
Delphi XE2 Professional
 
#14

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 14:17
Danke schon mal für die vielen Antworten.

Das mit den Views kenne ich jetzt nicht, werde ich mir aber unbedingt anschauen.
Ich habe jetzt ein SQL-Insert mit ca. 25 Parametern mit SQL.Add() zusammengebosselt, aber das sieht irgendwie so unübersichtlich aus.
Marc
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt, die 10. summt die Melodie von Tetris... | Wenn das die Lösung ist, dann hätte ich gerne mein Problem zurück! | engbarth.es
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

Registriert seit: 19. Aug 2004
Ort: Hof/Saale
1.746 Beiträge
 
Delphi 2007 Professional
 
#15

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 14:24
Zitat von NamenLozer:
Seit wann gibt es in Delphi Templates?
Vermutlich seit D2005 (D8?). Allerdings keine wie in C++, sondern Delphi-Referenz durchsuchenLive Templates in der IDE
Uli Gerhardt
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.798 Beiträge
 
Delphi 12 Athens
 
#16

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 14:27
Zitat von divBy0:
Ich habe jetzt ein SQL-Insert mit ca. 25 Parametern mit SQL.Add() zusammengebosselt, aber das sieht irgendwie so unübersichtlich aus.
Das glaub ich gerne. Was hast Du für eine Anwendung? Ist das im Prinzip ein Formular, das ausgefüllt wird, oder was komplizierteres? Wenn es ein Formular ist, dann machst Du ein Insert mit den 2-3 Pflichtfeldern und lässt den Rest von den datenbankgebundenen Komponenten ausfüllen, das ist etwas übersichtlicher.

Sherlock
Oliver
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#17

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 15:35
Zitat von divBy0:
Ich habe jetzt ein SQL-Insert mit ca. 25 Parametern mit SQL.Add() zusammengebosselt, aber das sieht irgendwie so unübersichtlich aus.
Es gibt immer wieder Situationen im Code, wo man konkret werden also z.B. ein komplexes SQL-INSERT befüllen muss.
Die einfachste Möglichkeit, hier übersicht zu schaffen, wäre die, das Du den schwer lesbaren Code in eine separate Prozedur mit einem guten Namen verlagerst und ordentlich kommentierst.

Eine weitere Möglichkeit hat Sherlock aufgezeigt: Verzichte ganz auf das Basteln von SQL-Anweisungen und überlasse das Delphi:
Verwende dazu Datenmodule, die die Verbindung zur Datenbank sowie die benötigten TxxQuery, TxxTable usw. enthalten.
Auf deinem Formular plazierst Du eine TDatasource, die sich mit den Datenmengen im Datenmodul verbindet.
Alle TDBEdits verbinden sich mit der TDatasource. Dann noch einen TDBNavigator (oder eine ähnliche Funktionalität per TButton) und -wupps- bist du fertig.

Der einzige kleine Nachteil an dieser RAD-Lösung: Es ist nirgens im Code dokumentiert, das (und wie!) die Daten in Richtung Datenbank geschubst werden. Dafür ist es stabil, sicher und funktioniert.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Benutzerbild von divBy0
divBy0

Registriert seit: 4. Mär 2007
Ort: Sponheim
1.021 Beiträge
 
Delphi XE2 Professional
 
#18

Re: Wie größere SQL Statements schreiben?

  Alt 18. Nov 2009, 15:41
Zitat von alzaimar:
Es gibt immer wieder Situationen im Code, wo man konkret werden also z.B. ein komplexes SQL-INSERT befüllen muss.
Die einfachste Möglichkeit, hier übersicht zu schaffen, wäre die, das Du den schwer lesbaren Code in eine separate Prozedur mit einem guten Namen verlagerst und ordentlich kommentierst.
So habe ich das, alles schön in einzelnen Prozeduren bzw. Methoden meiner Klasse.

Zitat von Sherlock:
Was hast Du für eine Anwendung? Ist das im Prinzip ein Formular, das ausgefüllt wird, oder was komplizierteres?
Es ist was komplizierteres, die Daten kommen fast ausschließlich von einer S7. Der Bediener kann zwar Daten bearbeiten, aber das sind nicht so viele.
Marc
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt, die 10. summt die Melodie von Tetris... | Wenn das die Lösung ist, dann hätte ich gerne mein Problem zurück! | engbarth.es
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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:07 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