AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Verschachtelte SQL Abfrage
Thema durchsuchen
Ansicht
Themen-Optionen

Verschachtelte SQL Abfrage

Ein Thema von Walter Landwehr · begonnen am 6. Nov 2017 · letzter Beitrag vom 8. Nov 2017
Antwort Antwort
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#1

AW: Verschachtelte SQL Abfrage

  Alt 7. Nov 2017, 08:12
Die aufgetretenen Fehler halte ich für Fehler in der Kommunikation hier in DP. Wahrscheinlich war Dein Tipp schon ganz richtig.

Die Aliase in einem Union sind ab dem ersten Union schlicht überflüssig, sie können halt auch angegeben werden, zählen tut einzig der Satz von Feldnamen aus dem ersten Statement.
Man könnte vielleicht noch argumentieren, dass bei größeren Union so etwas "Dokumentation" entsteht.
Feld Aliase aber in verschiedenen Selects des Union unterschiedlich zu nennen, ist sinnfrei- auch wenn es keinen Fehler wirft.
Ein Union erwartet lediglich gleiche Feldanzahl und Typ, Namen sind wurscht, namengebend sind die Spaltenname oder Aliase aus dem ersten Select. Wahrscheinlich macht er wenn möglich sogar implizite Typkonvertierung, würde ich mich allerdings nie drauf verlassen.

Die "" Sache bei Oracle dient einfach der Möglichkeit exakte Feldnamen mit Umlauten, Chinesisch usw. verwenden zu können. Dann wird halt nicht mehr case insensitiv gearbeitet, sondern buchstabengetreu der Feldname verwendet. Ich denke das gibt es so oder mit etwas anderer Syntax auch bei vielen anderen Herstellern, Backticks (`fElD naME`) bspw by mysql.
Ich halte da nichts von, arbeite quasi "historisch" mit englisch ASCII Alphabet.

Ich habe in meinen Posts einfach Anführungszeichen als Quoteindikator verwendet, die waren aber um den gesamten Aliasbegriff "as kontonummer". Dass einer der Aliase einen Fehler proviziert haben soll, ist mir nicht bewusst. Meine Anmerkungen drehten sich lediglich um Sinn und Verständnis des SQL Konstrukts.
Gruß, Jo
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.875 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Verschachtelte SQL Abfrage

  Alt 7. Nov 2017, 09:40
Firebird verwendet die "" im gleichen Sinne wie Oracle. Durch das Quoten werden Bezeichner case-sensitiv.

Ich verwende in diesem Fall gerne die Aliases, wenn diese auch nicht notwendig sind.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#3

AW: Verschachtelte SQL Abfrage

  Alt 7. Nov 2017, 10:02
Man könnte vielleicht noch argumentieren, dass bei größeren Union so etwas "Dokumentation" entsteht.

Manchmal hab ich den Eindruck, daß sich bei dem einen oder anderen Job ähnliche Denkschemata heraus bilden.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#4

AW: Verschachtelte SQL Abfrage

  Alt 7. Nov 2017, 11:50
Na klar, man macht im Laufe der Jahre halt die Erfahrung, dass lesbarer Code (der möglichst der "Muttersprache" oder dem eigenen Denkschema entspricht, auch nach Jahren noch verstanden wird. Man liest es halt wie einen Text aus 'nem Handbuch, 'ne Inhaltsangabe einer Kurzgeschichte ...

Einmal lesen und man weiß nach Jahren sofort, was man damals da so "verbrochen" hat und kann sofort da einsteigen, wo man irgendwann aufgehört hat. Man braucht weder lange zu suchen und zu grübeln: "Was der Henker hab' ich mir dabei gedacht". Oder auch nicht in eine (hoffentlich vorhandene) Dokumentation, Analyse, sonstige Vorgabe schauen. Beim Lesen wird sofort klar, was gemeint, was gewollt und was gemacht wurde. Und es wird einem recht schnell klar, ob die drei auch zum gleichen Ergebnis führen. Wenn nicht, macht man da weiter, wo man mal aufgehört hat.

Könnte man das als "Debuggen durch Verständlichkeit" bezeichnen?
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#5

AW: Verschachtelte SQL Abfrage

  Alt 8. Nov 2017, 14:52

Manchmal hab ich den Eindruck, ..
.. man macht im Laufe der Jahre halt die Erfahrung,
--
Könnte man das als "Debuggen durch Verständlichkeit" bezeichnen?

Also das wichtigste ist natürlich die Erfahrung, dass man sich nicht mehr alles merken kann, ab einem gewissen Alter!

Debuggen ist so eine Sache bei SQL. Die Statements sind meist relativ übersichtlich. Die eigentlichen Bugs hängen ja oft in den Datensätzen (besonders bei Importen)-
Für mich auch ein Grund, alles solgane mit SQL zu machen- was auch wunderbare Prüfmöglichkeiten bietet-, bis es läuft und validierte Daten liefert, dann erst ins Programm.
Gruß, Jo
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#6

AW: Verschachtelte SQL Abfrage

  Alt 8. Nov 2017, 16:08
Für mich auch ein Grund, alles solgane mit SQL zu machen- was auch wunderbare Prüfmöglichkeiten bietet-, bis es läuft und validierte Daten liefert, dann erst ins Programm.
Ja, ganz klar, erst wenn's auf der Datenbank vollkomen korrekt funktioniert, wird's ins Programm aufgenommen.
Debuggen ist so eine Sache bei SQL. Die Statements sind meist relativ übersichtlich. Die eigentlichen Bugs hängen ja oft in den Datensätzen (besonders bei Importen)-
Mit dem Debuggen meinte ich eigentlich auch mehr so: "Die eigenen Gedankengänge nochmal hinterfragen, steht da das, was gemeint und gewollt war." Weniger, ob es aus technischer Sicht korrekt ist.

Je komplexer SQL wird, um so größer ist die Wahrscheinlichkeit, dass sich logische Fehler einschleichen, auch dann, wenn das, was man da gebaut hat, technisch vollkommen fehlerfrei funktioniert.

Also eher die Suche nach abstrakten, logischen Fehlern.
Technische (syntaktische) Fehler bekommt man ja beim Ausführen sofort "um die Ohren gehauen".

In PL/SQL-Scripten größeren Umfanges kann dann die Fehlersuche schonmal etwas aufwändiger werden
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#7

AW: Verschachtelte SQL Abfrage

  Alt 8. Nov 2017, 16:23
Mit dem Debuggen meinte ich eigentlich auch mehr so: "Die eigenen Gedankengänge nochmal hinterfragen, steht da das, was gemeint und gewollt war." Weniger, ob es aus technischer Sicht korrekt ist.

Technische (syntaktische) Fehler bekommt man ja beim Ausführen sofort "um die Ohren gehauen".

In PL/SQL-Scripten größeren Umfanges kann dann die Fehlersuche schonmal etwas aufwändiger werden
Ok, vielleicht "prebuggen"?
Ja, Syntaxfehler sind die schönsten, solange die Fehlermeldung hablwegs fair ist.
Eine logischer Fehler in einer Auswertung kann es dann doch in sich haben. (Siehe Thread nebenan, gleicher Titel)

Und PL/SQL, da nehme ich mir dann doch gerne mal den Debugger.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#8

AW: Verschachtelte SQL Abfrage

  Alt 8. Nov 2017, 16:56
Mit dem Debuggen meinte ich eigentlich auch mehr so: "Die eigenen Gedankengänge nochmal hinterfragen, steht da das, was gemeint und gewollt war."


vielleicht noch um "..und versteht die DB was ich gemeint habe" ergänzen.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#9

AW: Verschachtelte SQL Abfrage

  Alt 8. Nov 2017, 17:14
Ja, da ist durchaus was dran.

Die DB versteht das, was ich schreibe, während ich beim Lesen meines geschriebenen ggfls. verstehe, was ich meinte, auch wenn das so explizit dort nicht steht.

Die DB nimmt halt alles wörtlich, wir Menschen tendieren eher zum Interpretieren / zwischen den Zeilen lesen.
  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 22:09 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