piomode1 Geschrieben 1. Februar 2002 Geschrieben 1. Februar 2002 Hi, Leute! Ich habe die unpraktische Erfahrung gemacht, daß unter VBA nur Aktionsabfragen als String generiert und dann mit 'docmd.runsql' ausgeführt werden können. Gibt es eine Möglichkeit, "dynamische" Auswahlabfragen mit Hilfe der VBA zu erzeugen. "Dynamisch" heißt hier: Ich weiß im Vorwege nicht, welche Felder ich in der Abfrage berücksichtigen möchte. Oder kann man VBA irgenwie austricksen (z.B. eine Aktualisierung vortäuschen (setze in FeldX den Wert aus FeldX) und dann mit einem Recordset durch die Datensätze wandern)? Zitieren
Meenzer Geschrieben 1. Februar 2002 Geschrieben 1. Februar 2002 Hi! Kannst Du ein konkretes Beispiel nennen, weil ich kann mir im Augenblick nicht genau vorstellen, was Du machen möchtest. Gruss Zitieren
piomode1 Geschrieben 1. Februar 2002 Autor Geschrieben 1. Februar 2002 Hi, Mercutio! Konkretes Beispiel: Ich habe eine Tabelle mit x "relevanten" Feldern (x>9 möglich!). "Relevant" hier: In diesen Feldern muß etwas stehen. (Anm.: Aus gegebenen Gründen ist es nicht möglich, in der Tabelle 'Eingabe erforderlich' auf 'Ja' zu stellen!) Ich möchte nun wissen, in jeweils wievielen Datensätzen welches Feld nicht gefüllt ist. Problem: Access erlaubt nur max. 9 Oder-Verknüpfungen! Sonst könnte ich es auch innerhalb einer festen Abfrage lösen: IstNull(Feld1) oder IstNull(Feld2) oder ... oder IstNull(Feld9) Ergebnis: Ich hätte alle Datensätze in denen mind. ein relevantes Feld nicht ausgefüllt ist. Bis jetzt habe ich mir bisher folgendermaßen beholfen: Ich habe für jedes relevante Feld zwei(!) Abfragen. 1) Filtere nach Datensätzen: IstNull(ein_relevantes_Feld) 2) Anzahl der Datensätze aus vorheriger Abfrage (Access sagt sinngemäß "Ist mir zu kompliziert!", wenn ich beides in eine Abfrage packe!!) Per 'docmd.runsql...<Anfügeabfrage>' schreibe ich dann in eine Tabelle den Feldnamen (bzw. eine anwenderfreundliche Bezeichnung) und die ermittelte Anzahl. Unschön: Ich muß für jedes relevate Feld zwei Auswahlabfragen generieren, die ich dann in VBA mit 'docmd.openquery' öffne. Dieses Vorgehen überfüllt das Datenbankfenster (und auch das Ausblenden des Objektes ist keine dauerhafte Lösung)! Ziel: Ich möchte im VBA-Code nur noch die Namen der relevanten Felder reinschreiben, die Auswahlabfrage wird generiert über einen SQL-String und ausgeführt. Ich begebe mich einmal auf die Suche nach folgender Vorgehensweise: a) 'CreateDatabaseQuery' (o.ä.) mit folgendem SQL-Inhalt unter folgendem Namen. Ausführen c) Löschen d) Nächstes relevantes Feld e) Vorhanden? Ja: a / Nein: Ende Hat jemand schon einmal etwas ähnliches aufgebaut? Zitieren
piomode1 Geschrieben 11. März 2002 Autor Geschrieben 11. März 2002 Hi, Leute! Ich habe in der Zwischenzeit herausgefunden, daß ich mit .OpenRecordset("Abfragename") weiterkomme: Man kann statt des Abfragenamens auch einen (zusammengebauten) SQL-String übergeben. Vielen Dank an alle!!! Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.