Zum Inhalt springen

Problem mit WHERE


etops

Empfohlene Beiträge

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-

Link zu diesem Kommentar
Auf anderen Seiten teilen

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... :D

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

Link zu diesem Kommentar
Auf anderen Seiten teilen

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.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...