Zum Inhalt springen

Hilfe bei Query


hyperion

Empfohlene Beiträge

Hallo,

leider habe ich momentan Schwierigkeiten einen Query zu schreiben.

Ich habe folgende Tabelle

Tab1

ID   Gebiet   Marke  Status

1    Nord      A        verkauft

2    Süd       B        verkauft

3    Nord      B        verkauft

4    Nord      A        offen

5    Süd       B        offen
Nun will ich einen Query derm ir das Ergbenis liefert:

Gebiet   Marke   Verkauft   Offen

Nord     A          1            1

Nord     B          1             0

Süd      B          1             0
Ich hab shcon 1000 Query probiert und nie hat es funktioniert.

select

  gebiet, 

  marke,

  count(status) as AnzahlVerkauft

from

   tab1

where 

  status = 'verkauft'

group by  gebiet, 

  marke,

Diese Version funktioniert, allerdings nur für einen Status. In diesem Fall 'verkauft'. Wie ich jetzt noch die Spalte AnzahlOffen und andere hinzubekomme weiß ich nicht.

Steh ich auf dem Schlauch oder ist die Aufgabe schwer?

Gruß hyperion

Link zu diesem Kommentar
Auf anderen Seiten teilen

Es handelt sich um MSAccess.

Mit dem Pivottabellenassisten habe ich es bereits probiert und bin leider gescheitert. Ein manueller AUfbau ist auch nciht möglich, da MSAccess kein Case unterstützt.

Mit Subselects habe ich es auch versucht. Leider bekomme ich hier bei ANzahlVerkauft die richtigen Werte und bei AnzahlOffen die selben Werte wie bei AnzahlVerkauft -> falsch

SELECT 

  ssev.Gebiet, 

  ssev.Marke, 

  ssev.Niederlassung, 

  Count(ssev.Status) AS AnzahlVerkauft,

  count(sso.status) as AnzahlOffen

FROM 

  (SELECT

     Projekte.Gebiet,

     Produkte.Marke, 

     Vertriebspartner.Niederlassung,

     Projekte.Status AS Status

  FROM 

    Vertriebspartner

  INNER JOIN 

    (Produkte

  INNER JOIN 

     Projekte 

  ON 

     Produkte.ModellID=Projekte.ModellID) 

  ON 

     Vertriebspartner.VertriebspartnerID=Projekte.VertriebspartnerID

  WHERE

    projekte.status = 'endverkauft'

   ) AS ssev,

   (SELECT

     Projekte.Gebiet,

     Produkte.Marke, 

     Vertriebspartner.Niederlassung,

     Projekte.Status AS Status

   FROM 

     Vertriebspartner

   INNER JOIN 

    (Produkte

   INNER JOIN 

     Projekte 

   ON 

     Produkte.ModellID=Projekte.ModellID) 

   ON 

     Vertriebspartner.VertriebspartnerID=Projekte.VertriebspartnerID

   WHERE

      projekte.status = 'offen'

   ) AS sso

GROUP BY ssev.Gebiet, ssev.Marke, ssev.Niederlassung;

Gruß hyperion

Link zu diesem Kommentar
Auf anderen Seiten teilen

Nah, das is so einfach, da braucht man keine Subselects oder Pivot


SELECT gebiet,

	   marke,

	   SUM(CASE WHEN verkauft = 'verkauft' THEN 1 ELSE 0 END) [verkauft],

	   SUM(CASE WHEN verkauft ='offen' THEN 1 ELSE 0 END) [offen]

FROM tabelle

GROUP BY gebiet, marke

Das wichtige dran is das Prinzip. Was den Access Dialekt angeht :

iif(verkauft='verkauft',1,0),

iif(verkauft='offen',1,0)

Gruß

Sven

Link zu diesem Kommentar
Auf anderen Seiten teilen

Ich habe leider keine MS Systeme, somit kann ich es nicht testen. Ich denke das mit dem Pivot sollte schon das richtige sein.

Baue doch das Statement erst für einen Wert auf, dann für den zweiten usw.

Im Moment verstehe ich nicht, warum Du Joins brauchst, denn in Deinem ersten Post hattest Du die nicht erwähnt. Wenn Du die Joins brauchst, dann mache doch daraus einen View, den Du dann in Deiner Pivot Tabelle verwendest.

Link zu diesem Kommentar
Auf anderen Seiten teilen

Hallo,

ich habe es jetzt doch noch mit dem Pivotassistenten geschafft.

Die Joins habe ich am Anfang nicht erwähnt, weil ich das erste Beispiel noch auf das wesentliche beschränken wollte.

Und Danke für den TIpp mit dem iff, das kann ich bestimtm noch irgendwann brauchen.

Gruß hyperion

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