Как отфильтровать сводную таблицу с помощью Eloquent?
м, используя сводную таблицу на проекте I 'Я работаю с, чтобы получить работы пользователей.
Например:User::find(1)->works
дает мне работы пользователя с ID 1.
Дело в том, что я хочу отфильтровать эти результаты с помощью дополнительных сводных данных.
Что-то вроде:
User::find(1)->works->pivot->where('active',1)->get();
В котором активным является столбец I 'установить в моей сводной таблице user_works.
Это моя связанная часть моей модели User.php:
belongsToMany('Work','user_works')->withPivot('active')->withTimestamps();
}
}
Это моя родственная часть моей модели Work.php:
belongsToMany('User','user_works')->withPivot('active')->withTimestamps();
}
}
Это моя схема сводной таблицы:
increments('id');
$table->integer('user_id')->unsigned()->default(0);
$table->integer('work_id')->unsigned()->default(0);
$table->enum('active',array('0','1'))->default(1);
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
$table->foreign('work_id')->references('id')->on('works')->onDelete('cascade');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::drop('user_works');
}
}
Есть ли способ получить данные, не создавая новую модель для сводной таблицы?
Заранее спасибо,
Редактировать: Я могу отфильтровать таким образом:
return User::find(1)->works()->where('user_works.active','=','1')->get();
Мне пришлось набрать имя таблицы raw. Но есть ли лучший способ получить это без его использования?