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:
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")
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;
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;
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
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!