Heim >Datenbank >MySQL-Tutorial >Wie kann man Produktdaten in Laravel mithilfe einer Unterabfrage in „WHERE IN' effizient abrufen?

Wie kann man Produktdaten in Laravel mithilfe einer Unterabfrage in „WHERE IN' effizient abrufen?

Barbara Streisand
Barbara StreisandOriginal
2024-12-09 13:49:11887Durchsuche

How to Efficiently Retrieve Product Data in Laravel Using a Subquery in `WHERE IN`?

Laravel-Unterabfrage WHERE IN:

Sie suchen eine leistungsstarke Möglichkeit, Produktdaten mithilfe einer Unterabfrage aus der Produkttabelle in Laravel abzurufen um die einzubeziehenden product_id-Werte anzugeben. Während es eine Join-Alternative gibt, bevorzugen Sie zu Optimierungszwecken einen auf Unterabfragen basierenden Ansatz.

Lösung:

Unten finden Sie den Code, der Ihre Anforderung erfüllt und Unterabfragen innerhalb der nutzt worin Klausel:

Products::whereIn('id', function($query){
    $query->select('paper_type_id')
        ->from(with(new ProductCategory)->getTable())
        ->whereIn('category_id', ['223', '15'])
        ->where('active', 1);
})
->get();

Erklärung:

  • Die Abfrage beginnt mit einer Produktmodellbasis, die die Zieltabelle darstellt, aus der wir Daten abrufen möchten.
  • Die whereIn-Klausel wird verwendet und gibt die ID-Spalte der Produkttabelle
    als Spalte an auswerten.
  • Ein verschachtelter Abschluss wird verwendet, um die Unterabfrage zu definieren. Innerhalb dieses Abschlusses wählen wir die paper_type_id aus einer temporären Tabelle aus, die mit (new ProductCategory)->getTable() erstellt wurde.
  • Die Unterabfrage wendet dann die erforderlichen Filter an, einschließlich whereIn('category_id', ['223 ', '15']), um die Ergebnisse auf bestimmte Kategorien zu beschränken, und where('active', 1), um nur aktive einzuschließen Produkte.
  • Abschließend wird die gesamte Abfrage mit get() ausgeführt, wodurch die gewünschten Produktdaten effizient abgerufen werden.

Das obige ist der detaillierte Inhalt vonWie kann man Produktdaten in Laravel mithilfe einer Unterabfrage in „WHERE IN' effizient abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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