etops Geschrieben 25. Juli 2003 Geschrieben 25. Juli 2003 Hallo, wie kann ich in Access97 eine SQL-Abfrage darstellen, die mir die Auswahl mehrerer Felder in der WHERE-Klausel ermöglicht? Erster Ansatz war so, liefert aber falsche Werte: SELECT COUNT (*) AS [Anzahl bla] FROM ABC WHERE Verantwortl1a = 'bla' AND ((Verantwortl1b = 'bla' OR '--') AND (Verantwortl1c = 'bla' OR '--')) AND ((Verantwortl2a = 'bla' OR '--') AND (Verantwortl2b = 'bla' OR '--') AND (Verantwortl2c = 'bla' OR '--')) AND ((Verantwortl3a = 'bla' OR '--') AND (Verantwortl3b = 'bla' OR '--') AND (Verantwortl3c = 'bla' OR '--')); Zur Erläuterung: Das Feld Verantwortl1a enthält immer einen Wert; ich möchte jetzt wissen, wie oft jeder einzelne Wert, der zusätzlich zu Verantwortl1a auch in den anderen Feldern (--> also insgesamt) auftaucht. Die Verknüpfung mit OR ist deswegen falsch, weil der Inhalt von Verantwortl1a zwar nicht in Verantwortl1b und 1c auftauchen kann, dafür aber noch je einmal in 2(a, b, c) oder 3(a, b, c). Wahrscheinlich hat das jetzt keiner kapiert, aber ich bin trotzdem für jeden Ansatz dankbar Danke + Gruß -etops-
HolzOnkel Geschrieben 25. Juli 2003 Geschrieben 25. Juli 2003 Original geschrieben von etops SELECT COUNT (*) AS [Anzahl bla] FROM ABC WHERE Verantwortl1a = 'bla' AND ((Verantwortl1b = 'bla' OR '--') AND (Verantwortl1c = 'bla' OR '--')) AND ((Verantwortl2a = 'bla' OR '--') AND (Verantwortl2b = 'bla' OR '--') AND (Verantwortl2c = 'bla' OR '--')) AND ((Verantwortl3a = 'bla' OR '--') AND (Verantwortl3b = 'bla' OR '--') AND (Verantwortl3c = 'bla' OR '--')); Zur Erläuterung: Das Feld Verantwortl1a enthält immer einen Wert; ich möchte jetzt wissen, wie oft jeder einzelne Wert, der zusätzlich zu Verantwortl1a auch in den anderen Feldern (--> also insgesamt) auftaucht. Die Verknüpfung mit OR ist deswegen falsch, weil der Inhalt von Verantwortl1a zwar nicht in Verantwortl1b und 1c auftauchen kann, dafür aber noch je einmal in 2(a, b, c) oder 3(a, b, c). Wahrscheinlich hat das jetzt keiner kapiert, aber ich bin trotzdem für jeden Ansatz dankbar Mit letzterem könntest Du durchaus recht haben... Okay, mal schauen, ob ich das richtig gepeilt habe... erste Frage: wenn ich das Wort "kann" bei Dir richtig verstanden habe, könnte die Abfrage dann nicht einfach so lauten: SELECT COUNT (*) AS [Anzahl bla] FROM ABC WHERE Verantwortl1a = 'bla' AND ( Verantwortl2a = 'bla' OR Verantwortl2b = 'bla' OR Verantwortl2c = 'bla' OR Verantwortl3a = 'bla' OR Verantwortl3b = 'bla' OR Verantwortl3c = 'bla' ) So, wie Du das geschrieben hast, fallen die Felder 1b und 1c ja eh aus der Abfrage raus, weil der Wert da nicht auftauchen kann. Die nächste Frage wäre dabei: brauchst Du den Wert '--' wirklich? Aus der Fragestellung heraus kam es mir so vor, als würdest Du nur wissen wollen, wo der Wert 'bla' in 1a und in einem der Felder 2(a,b,c) oder 3(a,b,c) vorkommt. In der Abfrage oben ist natürlich nicht inbegriffen, dass der Wert nur in einem der zusätzlichen Felder auftauchen soll... Gruss, der Onkel
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden