Zitat von
marabu:
Hallo.
Deine erste
Query hast du ja schon hinbekommen:
SQL-Code:
select *
from WellenInformationen
where :filterexpr
order by :wsort
Wenn die zweite
Query alle Lagerstellen der Wellen aus der ersten
Query enthalten soll, dann müsste sie etwa so aussehen:
SQL-Code:
select *
from LagerStellen
where WLfdNr in (
select lfdnr
from WellenInformationen
where :filterexpr )
order by :lsort
Der Parameter :filterexpr muss dann mindestens den Filter-Ausdruck enthalten, der auch für die erste
Query verwendet wurde.
Grüße vom marabu
Danke für den Tip, das hat mir geholfen. Ich hab es jetzt in einem
Query gemacht und ich denke das sollte klappen. Vielleicht könnt ihr mit einen Tip geben falls jemand daran etwas auffällt.
SQL-Code:
with DM1.ffQuery2 do
begin
Close();
with
SQL do
begin
Clear;
Add( '
SELECT * FROM WellenInformationen, Lagerdaten ' );
s := '
WHERE WellenInformationen.Idx = Lagerdaten.WiIdx';
if cxGrid1DBTableView1.DataController.Filter.FilterText <> '
'
then begin
s := s + '
AND ' + cxGrid1DBTableView1.DataController.Filter.FilterText;
end;
Add( s );
end;
Open();
end;
Die erste
Query brauche ich glaub gar nicht weil das cxgrid mir das ja direkt anzeigt, die müsste ich wohl nur selber machen wenn ich das Grid in den GridMode schalten würde.
Ein Problem habe ich noch. Ich lass mir ja den FilterText von meinem cxGrid direkt zurück geben, den ich dann direkt als
SQL Statement einfüge. Das geht bei allen Feldern außer bei meinem Datumsfeld. Das Feld ist vom Typ "SysTools Date", muss ich da was beachten? Ich bekomme als Meldung immer einen Type mismatch.
Beim Feld "SysTools Time" funktionierts ohen Probleme
In C geschrieben und schön war zuletzt Franz Schuberts 9. Symphonie