Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Problem mit WHERE

Empfohlene Antworten

Veröffentlicht

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-

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

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.