Eloquent Sum of Relation's Column
Eine der Herausforderungen bei der Arbeit mit einer E-Commerce-Anwendung ist das Abrufen aggregierter Daten aus verwandten Modellen. Im Zusammenhang mit einem Warenkorb müssen Sie möglicherweise die Gesamtkosten der zum Warenkorb hinzugefügten Produkte ermitteln.
Nehmen wir die folgenden Modelle an:
Anhand der Beziehungen von Eloquent können wir Folgendes feststellen:
Um die Anzahl der Produkte im Warenkorb eines Benutzers zu ermitteln, können Sie ganz einfach Folgendes verwenden:
Auth::user()->cart()->count();
Um die Gesamtkosten der Produkte zu berechnen, muss jedoch ermittelt werden Summe ihrer Preise. Um dies mit Eloquent zu tun, ohne auf eine Rohabfrage zurückzugreifen:
Auth::user()->products()->sum('price');
Die Methode „products()“ ruft alle Produkte ab, die einem Benutzer über die Beziehungen „belongsTo“ und „hasMany“ zugeordnet sind, während die Methode „sum ('Preis')'-Methode aggregiert die 'Preis'-Werte der Produkte.
Dieser Eloquent-Ansatz bietet eine saubere und prägnante Möglichkeit, den gewünschten Vorgang durchzuführen und nutzt dabei die Leistungsfähigkeit seiner Beziehungsmanagementfunktionen.
Das obige ist der detaillierte Inhalt vonWie berechnet man die Gesamtkosten der Produkte in einem Warenkorb mithilfe eloquenter Beziehungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!