Heim > Datenbank > MySQL-Tutorial > Wie kann ich Angebote abfragen, die eine bestimmte Sportart in einer Viele-zu-Viele-Beziehung enthalten?

Wie kann ich Angebote abfragen, die eine bestimmte Sportart in einer Viele-zu-Viele-Beziehung enthalten?

DDD
Freigeben: 2025-01-05 07:20:44
Original
951 Leute haben es durchsucht

How to Query for Offers Containing a Specific Set of Sports in a Many-to-Many Relationship?

SQL-Fehler: „wobei der verbundene Satz alle Werte enthalten muss, aber möglicherweise mehr enthält“ für Angebote und Sportfilter

In unserer Datenbank haben wir drei Tabellen: Angebote, Sports und die Join-Tabelle Offers_Sports. Wir möchten Angebote abrufen, die eine bestimmte Auswahl an Sportarten umfassen, mit der Voraussetzung, dass alle angegebenen Sportarten vorhanden sein müssen, aber auch zusätzliche Sportarten enthalten sein können.

Berücksichtigen Sie beispielsweise die folgenden Angebote:

  • Leicht: Yoga, Bodyboarding
  • Mittel: Yoga, Bodyboarding, Surfen
  • Alle: Yoga, Bodyboarding, Surfen, Parasailing, Fallschirmspringen

Wenn wir nach Angeboten suchen, die „Bodyboarding“ und „Surfen“ enthalten, erwarten wir, dass wir sowohl „Mittel“ als auch „Alle“ erhalten, jedoch nicht „Leicht“. Unsere aktuelle Abfrage:

Offer.joins(:sports)
     .where(sports: { name: ["Bodyboarding", "Surfing"] })
     .group("sports.name")
     .having("COUNT(distinct sports.name) = 2")
Nach dem Login kopieren

Und das SQL-Äquivalent:

SELECT "offers".* 
FROM "offers" 
INNER JOIN "offers_sports" ON "offers_sports"."offer_id" = "offers"."id"     
INNER JOIN "sports" ON "sports"."id" = "offers_sports"."sport_id" 
  WHERE "sports"."name" IN ('Bodyboarding', 'Surfing') 
GROUP BY sports.name 
HAVING COUNT(distinct sports.name) = 2;
Nach dem Login kopieren

Keine Ergebnisse zurückgeben.

Um dies zu beheben, ändern wir unsere Abfrage so, dass sie nach gruppiert die Angebots-ID anstelle des Sportnamens:

SELECT o.*
FROM   sports        s
JOIN   offers_sports os ON os.sport_id = s.id
JOIN   offers        o  ON os.offer_id = o.id
WHERE  s.name IN ('Bodyboarding', 'Surfing') 
GROUP  BY o.id  -- !!
HAVING count(*) = 2;
Nach dem Login kopieren

oder in ActiveRecord:

class Offer < ActiveRecord::Base
  has_and_belongs_to_many :sports
  def self.includes_sports(*sport_names)
    joins(:sports)
      .where(sports: { name: sport_names })
      .group('offers.id')
      .having("count(*) = ?", sport_names.size)
  end
end
Nach dem Login kopieren

Diese Änderung stellt sicher, dass wir die Ergebnisse entsprechend gruppieren und die erforderlichen Filterkriterien anwenden, um die gewünschten Angebote abzurufen, die die angegebenen Sportarten umfassen.

Das obige ist der detaillierte Inhalt vonWie kann ich Angebote abfragen, die eine bestimmte Sportart in einer Viele-zu-Viele-Beziehung enthalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage