AGB  ·  Datenschutz  ·  Impressum  







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

SQL Tutorial neue Schreibweise ?!

Ein Thema von Davidlocke13 · begonnen am 27. Sep 2012 · letzter Beitrag vom 28. Sep 2012
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Davidlocke13
Davidlocke13

Registriert seit: 19. Sep 2012
Ort: MD (Sachsen-Anhalt)
166 Beiträge
 
Delphi 2010 Enterprise
 
#1

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 15:31
Meine so was !

Alt:
Code:
SELECT c.*,m.*
FROM Mitarbeiter m, cities c
WHERE 1=1
 and m.ort = c.full_name_nd(+)
ORDER BY Name
Neu:
Code:
SELECT c.*,m.*
FROM Mitarbeiter m
left join cities c
  on m.ort = c.full_name_nd and c.cc_fips = 'GM'
WHERE 1=1
ORDER BY Name
David
ApfelsineMandarineAllesGleich
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 15:34
Na ob man SQL92 als neu bezeichnen kann
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Davidlocke13
Davidlocke13

Registriert seit: 19. Sep 2012
Ort: MD (Sachsen-Anhalt)
166 Beiträge
 
Delphi 2010 Enterprise
 
#3

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 15:39
Naja habe gehört das es beide Schreibweisen gibt und wenn ich SQL lerne dann auch gleich die richtige Schreibweise und so weit ich weis ist ein halt neuer !
David
ApfelsineMandarineAllesGleich
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 15:45
vielleicht hilft Dir das schon weiter.

Ansonsten, Fragen stellen.

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

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 16:06
Also die Ansi Joins aus SQL/92 sind deutlich besser lesbar als die Oracle Joins,
weil die Verknüpfungen zwischen den Tabellen getrennt von den Filterbedingungen sind.

Wenn man 4 und mehr Tabellen verknüpfen muss, dann kann man bei der alten Syntax leicht mal einen Teilausdruck vergessen.
Das führt dann dazu, dass man mehr Datensätze bekommt als man eigentlich wollte.
Häufig fällt das erst dann auf wenn die Datenbank mit echten Daten gefüllt ist.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von Davidlocke13
Davidlocke13

Registriert seit: 19. Sep 2012
Ort: MD (Sachsen-Anhalt)
166 Beiträge
 
Delphi 2010 Enterprise
 
#6

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 16:11
Ok das ist doch schon mal ne Erklärung ich ich verstehe !

THX
David
ApfelsineMandarineAllesGleich
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 16:32
Zitat:
Ich weiß nicht genau, könnte mir aber vorstellen, dass Oracle damit relativ spät um die Ecke gekommen ist (vielleicht weiß dazu irgendjemand was)
Andersherum bei SQL87 gab es keine expliziten Joins und so hat Oracle die eigene Notation eingeführt.
Als die expliziten joins dann in SQL92 eingeführt wurden, hielten die Oracle-Jünger an "ihrem" Standard fest.
Zitat:
Persönlich finde ich die "alte" Schreibweise intuitiver und auch übersichtlicher. *1 Spätestens, wenn Du ein Dutzend oder mehr joins hast, ist das allerdings schwer zu begründen, also tatsächlich nur Gewohnheit.
Sehe ich anders. Explizite Joins finde ich besser lesbar, zudem die Join-Bedingungen hier strikt von den Filterbedingungen getrennt werden können.
Zitat:
Größter Knackpunkt an der alten Oracle (+) Notation ist vielleicht die fehlende Darstellungsmöglichkeit für Full Outer Joins, die man dann über ein Union in 2 Schritten darstellen müsste und natürlich die Inkompatibilität zu vielen anderen RDBMS.
Wobei es auch Versuche/Lösungen für andere DBMS gab ( z.B. FyRacle: FireBird Oracle Modus; hierbei ga es einen Dienst, der die Oracle Syntax in Standard-SQL gewandelt hat)
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 16:39
Dann frag ich mal in die Runde:
Code:
select irgendwas
from tab1,tab2,tab3
where tab1.Reference like 'Test%'
  and tab1.id=tab2.id(+)
  and tab3.myid(+)=tab2.myid
  and tab3.Name(+) like 'Rüsselm%'
wie macht man da ein vernünftiges "Neues Join" draus.

@Jobo
Zitat:
Seit Oracle9i können sie die Ansi-SQL-Standardsyntax für Outer Joins verwenden.
Und alle Beispiele nutzen dann die "alte" Oracle syntax

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

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

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 16:48
SQL-Code:
select
    irgendwas
from
    tab1
        right join tab2 on tab2.id = tab1.id
             left join tab3 on tab3.myid = tab2.myid and tab3.Name like 'Rüsselm%'
where
    tab1.Reference like 'Test%';
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: SQL Tutorial neue Schreibweise ?!

  Alt 27. Sep 2012, 16:54
@Mkinzler
Danke, ich wäre nie auf die Idee gekommen das in die/den Join zu packen.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 19:14 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