Как отфильтровать сводную таблицу с помощью 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. Но есть ли лучший способ получить это без его использования?

Ответы на вопрос(3)

Ваш ответ на вопрос