etops Geschrieben 25. Juli 2003 Teilen 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- Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
HolzOnkel Geschrieben 25. Juli 2003 Teilen 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 Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
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.