AGB  ·  Datenschutz  ·  Impressum  







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

Fehler bei Left Join

Ein Thema von Ykcim · begonnen am 13. Sep 2021 · letzter Beitrag vom 14. Sep 2021
 
Delphi.Narium

Registriert seit: 27. Nov 2017
2.558 Beiträge
 
Delphi 7 Professional
 
#18

AW: Fehler bei Left Join

  Alt 13. Sep 2021, 18:45
Vermutlich sollte Dein SQL in etwa so aussehen, damit es per HeidiSQL oder sonsteiner Datenbankoberfläche ausführbar ist.
SQL-Code:
SELECT
  a.zynrefkl AS 'Artikelnummer',
  a.afg_oms1 AS 'Artikelbezeichnung 1',
  concat('VPE:',a.per__chk,' Stück') AS 'Artikelbezeichnung 2',
  'AS 'Artikelbezeichnung 3',
  'AS 'Artikelbezeichnung 4',
  'AS 'Artikelbezeichnung 5',
  'AS 'Artikelbezeichnung 6',
  b.in__vrrd AS 'Bestand',
  a.per__chk AS 'Abgreifmenge',
  a.minstock AS 'Mindestbestand',
  CASE WHEN b.in__vrrd < a.minstock THEN
    'Mindestmenge unterschritten'
  ELSE
    ''
  END AS 'Bestandskommentar',
  'AS 'Kommentar',
  (
    SELECT SUM(COALESCE(c.b_aantal,0))
    FROM bstlyn__ c
    WHERE c.afg__ref = a.afg__ref
    AND c.levv_dat < GETDATE()
    AND c.lbn__ref = ''
  ) AS 'Rückstand',
  (
    SELECT SUM(COALESCE(d.aant_uit,0))
    FROM hisafg__ d
    WHERE d.afg__ref = a.afg__ref
  ) AS 'Gesamtverbrauch'
FROM afgart__ a
LEFT JOIN afgant__ b ON b.afg__ref = a.afg__ref
LEFT JOIN gegdet__ e ON e.det__ref = a.afg__ref AND vrg__ref = '000002AND tabname_ = 'afgart__'
WHERE a.kla__rpn = 'MEYLE'
AND a.zynrefkl <> ''
AND (e.antw_txt <> '1OR e.antw_txt IS NULL)
GROUP BY a.zynrefkl, a.afg_oms1, b.in__vrrd, a.per__chk, a.minstock, a.afg__ref
ORDER BY a.zynrefkl
Um daraus nun kompilierbaren Delphiquelltext zu erhalten benötigt man ein TMemo (WordWrap := false), einen TButton und folgende Routine:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  i : Integer;
begin
  for i := 0 to Memo1.Lines.Count - 1 do Memo1.Lines[i] := Format(' Query.SQL.Add(%s);',[QuotedStr(Memo1.Lines[i])]));
  Memo1.SelectAll;
  Memo1.CopyToClipboard;
end.
Als Ergebnis erhält man den Quelltext, den man dann einfach in der IDE an der passenden Stelle (per Copy&Paste) einfügt:
Delphi-Quellcode:
  Query.SQL.Add('SELECT');
  Query.SQL.Add(' a.zynrefkl AS ''Artikelnummer'',');
  Query.SQL.Add(' a.afg_oms1 AS ''Artikelbezeichnung 1'',');
  Query.SQL.Add(' concat(''VPE:'',a.per__chk,'' Stück'') AS ''Artikelbezeichnung 2'',');
  Query.SQL.Add(' '''' AS ''Artikelbezeichnung 3'',');
  Query.SQL.Add(' '''' AS ''Artikelbezeichnung 4'',');
  Query.SQL.Add(' '''' AS ''Artikelbezeichnung 5'',');
  Query.SQL.Add(' '''' AS ''Artikelbezeichnung 6'',');
  Query.SQL.Add(' b.in__vrrd AS ''Bestand'',');
  Query.SQL.Add(' a.per__chk AS ''Abgreifmenge'',');
  Query.SQL.Add(' a.minstock AS ''Mindestbestand'',');
  Query.SQL.Add(' CASE WHEN b.in__vrrd < a.minstock THEN');
  Query.SQL.Add(' ''Mindestmenge unterschritten''');
  Query.SQL.Add(' ELSE');
  Query.SQL.Add(' ''''');
  Query.SQL.Add(' END AS ''Bestandskommentar'',');
  Query.SQL.Add(' '''' AS ''Kommentar'',');
  Query.SQL.Add(' (');
  Query.SQL.Add(' SELECT SUM(COALESCE(c.b_aantal,0))');
  Query.SQL.Add(' FROM bstlyn__ c');
  Query.SQL.Add(' WHERE c.afg__ref = a.afg__ref');
  Query.SQL.Add(' AND c.levv_dat < GETDATE()');
  Query.SQL.Add(' AND c.lbn__ref = ''''');
  Query.SQL.Add(' ) AS ''Rückstand'',');
  Query.SQL.Add(' (');
  Query.SQL.Add(' SELECT SUM(COALESCE(d.aant_uit,0))');
  Query.SQL.Add(' FROM hisafg__ d');
  Query.SQL.Add(' WHERE d.afg__ref = a.afg__ref');
  Query.SQL.Add(' ) AS ''Gesamtverbrauch''');
  Query.SQL.Add('FROM afgart__ a');
  Query.SQL.Add('LEFT JOIN afgant__ b ON b.afg__ref = a.afg__ref');
  Query.SQL.Add('LEFT JOIN gegdet__ e ON e.det__ref = a.afg__ref AND vrg__ref = ''000002'' AND tabname_ = ''afgart__''');
  Query.SQL.Add('WHERE a.kla__rpn = ''MEYLE''');
  Query.SQL.Add('AND a.zynrefkl <> ''''');
  Query.SQL.Add('AND (e.antw_txt <> ''1'' OR e.antw_txt IS NULL)');
  Query.SQL.Add('GROUP BY a.zynrefkl, a.afg_oms1, b.in__vrrd, a.per__chk, a.minstock, a.afg__ref');
  Query.SQL.Add('ORDER BY a.zynrefkl');
Dürfte vermutlich schneller gehen, als alles per dutzender QuotedStr und vielen + als Einzeiler mit nur einem Query.SQL.Add irgendwie, hoffentlich kompilierbar, hinzubekommen und dann auch noch ein ausführbares SQL zu erhalten. Und das Nachzählen der ' kann dann auch entfallen

Auswand: 15 oder 30 Minuten?
(Einmalig und nicht bei jedem SQL auf's Neue )

Geändert von Delphi.Narium (13. Sep 2021 um 18:50 Uhr)
  Mit Zitat antworten Zitat
 


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 17:41 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