1. Weiterleitung zu NetzLiving.de
  2. Forum
    1. Unerledigte Themen
  3. zum neuen Forum
  • Anmelden
  • Suche
Dieses Thema
  • Alles
  • Dieses Thema
  • Dieses Forum
  • Seiten
  • Forum
  • Erweiterte Suche
  1. Informatik Forum
  2. Webmaster & Internet
  3. Entwicklung

sql version 4.0.23a

  • Cheez
  • 5. März 2006 um 22:07
  • Unerledigt
Hallo zusammen,

das Informatik-Forum geht in den Archivmodus, genaue Informationen kann man der entsprechenden Ankündigung entnehmen. Als Dankeschön für die Treue bekommt man von uns einen Gutscheincode (informatikforum30) womit man bei netzliving.de 30% auf das erste Jahr sparen kann. (Genaue Infos sind ebenfalls in der Ankündigung)

Vielen Dank für die Treue und das Verständnis!
  • Cheez
    Punkte
    605
    Beiträge
    76
    • 5. März 2006 um 22:07
    • #1

    an der hauptuni hat ja jeder student webspace mit einem apache und einem sql server 4.0.23a.

    lokal auf meinem rechner hab ich die sql version 4.1.8

    folgendes sql statement funktioniert bei mir local wunderbar, aber auf dem uni server nicht:

    SELECT o.name AS Name, o.ID AS objectID, o.beschreibung AS beschreibung

    FROM object o, (SELECT m.objectID as objectID from messgroesse m
    WHERE m.einheit = 'm'
    OR m.einheit = 'km'
    OR m.einheit = 'cm'
    OR m.einheit = 'dm'
    OR m.einheit = 'mm'
    OR m.einheit = 'mikrom') x

    WHERE x.objectID = o.ID
    GROUP BY o.name, o.ID;

    hat jemand eine Ahnung was ich ändern muss, damit es auch auf der älteren sql version funkt??

    danke.

  • Paulchen
    Gast
    • 5. März 2006 um 23:05
    • #2
    Zitat von Cheez

    hat jemand eine Ahnung was ich ändern muss, damit es auch auf der älteren sql version funkt??

    das subselect durch einen join ersetzen

  • Cheez
    Punkte
    605
    Beiträge
    76
    • 5. März 2006 um 23:55
    • #3

    uiui. hab noch nie ein join statement gemacht ;)

    SELECT o.name AS Name, o.ID AS objectID, o.beschreibung AS beschreibung
    FROM object as o JOIN (SELECT m.objectID as objectID from messgroesse m
    WHERE m.einheit = 'm'
    OR m.einheit = 'km'
    OR m.einheit = 'cm'
    OR m.einheit = 'dm'
    OR m.einheit = 'mm'
    OR m.einheit = 'mikrom') as x ON o.ID=x.objectID GROUP BY o.name, o.ID;


    so???
    irgendwie passts nicht...

  • zwutschkerl
    Punkte
    365
    Beiträge
    71
    • 6. März 2006 um 00:23
    • #4
    SQL
    SELECT o.name AS Name, o.ID AS objectID, o.beschreibung AS beschreibung
    FROM object o 
      INNER JOIN messgroesse m ON o.ID=m.objectID AND
                                              ( m.einheit = 'm'
                                                OR        m.einheit = 'km'
                                                OR        m.einheit = 'cm'
                                                OR        m.einheit = 'dm'
                                                OR        m.einheit = 'mm'
                                                OR        m.einheit = 'mikrom' )
    
    
    GROUP BY  o.name, o.ID;
    Alles anzeigen

    oder

    SQL
    SELECT o.name AS Name, o.ID AS objectID, o.beschreibung AS beschreibung
    FROM object o 
       INNER JOIN messgroesse m ON o.ID=m.objectID
    
    
    WHERE ( m.einheit = 'm' 
        OR        m.einheit = 'km'
          OR        m.einheit = 'cm'
          OR        m.einheit = 'dm'
          OR        m.einheit = 'mm'
          OR        m.einheit = 'mikrom' )
     
     GROUP BY  o.name, o.ID;
    Alles anzeigen

    Das obere is an sich optimaler, weil beim join die unnötigen Tupel schon ausgeschlossen werden, effektiv ist es aber wurscht, weil der SQL Server das Statement sowieso optimiert.

  • Cheez
    Punkte
    605
    Beiträge
    76
    • 6. März 2006 um 00:26
    • #5

    supa! danke.

  • Maximilian Rupp 27. Dezember 2024 um 12:06

    Hat das Thema aus dem Forum Programmieren nach Entwicklung verschoben.

  1. Datenschutzerklärung
  2. Impressum