У меня есть следующие таблицы Orders
, Lamps
и Lamp_Order
, которые являются таблицей pivot
. В таблице Lamp_Order
хранятся id
из Order
и Lamp
. Order
может содержать несколько одинаковых Lamps
. Так что может быть, например, есть 5 Lamps
с id
из 1, подключенным к тому же Order
. Я хочу получить счет того же Lamps
в Order
. Таким образом, этот метод или функция, которую я хочу сделать, должен в этом случае вернуть 5.
В настоящее время у меня есть эта функция в моем OrderController
для возврата Order
с соответствующим Lamps
:
public function index()
{
$orders = Order::all();
// Get the Lamps for each Order.
foreach ($orders as $order) {
$order->lamps;
}
return response()->json([
'orders' => $orders
], 200);
}
Ответ в моем vue
интерфейсе выглядит следующим образом:
Как видите, возвращаются некоторые лампы с одинаковым идентификатором. Вместо этого я хотел бы вернуть эту Лампу со счетом того, сколько раз она связана с этой Order
.
Моя Order
модель выглядит следующим образом:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Order extends Model
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email'
];
/**
* Get related Image.
*
* @return void
*/
public function image()
{
return $this->hasOne(Image::class);
}
/**
* Get related Lamps.
*
* @return void
*/
public function lamps()
{
return $this->belongsToMany(Lamp::class)->withPivot('room');
}
public function countSameRelationships()
{
}
/**
* Detach related lamps when deleting Orders.
*
* @return void
*/
public static function boot()
{
parent::boot();
static::deleting(function ($order) {
$order->lamps()->detach();
});
}
}
Я был размышляю о создании функции в модели Order
, которую я вызываю в функции index
в OrderController
. Может кто-нибудь сказать мне, есть ли какая-то уже существующая функция для подсчета этих «дублирующих» отношений? Или что было бы хорошим подходом для решения этой проблемы? Я предпочитаю решение возвращать правильные данные непосредственно из Laravel бэкэнда. Но если также возможно применить какую-то функцию фильтра для удаления и подсчета повторяющихся отношений, это также подойдет.