【发布时间】:2013-09-03 12:21:36
【问题描述】:
我在我正在处理的项目中使用数据透视表来获取用户的作品。
例如:User::find(1)->works 给了我 ID 为 1 的用户的作品。
问题是我想用额外的 Pivot 数据过滤这个结果。
类似:
User::find(1)->works->pivot->where('active',1)->get();
其中 active 是我在 user_works 数据透视表中设置的列。
这是我的 User.php 模型的相关部分:
<?php
class User extends Cartalyst\Sentry\Users\Eloquent\User {
public function works() {
return $this->belongsToMany('Work','user_works')->withPivot('active')->withTimestamps();
}
}
这是我的 Work.php 模型的相关部分:
<?php
class Work extends Eloquent {
public function users() {
return $this->belongsToMany('User','user_works')->withPivot('active')->withTimestamps();
}
}
这是我的数据透视表架构:
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
class CreateUserWorksTable extends Migration {
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('user_works', function(Blueprint $table) {
$table->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();
我必须输入原始表名。但是有没有更好的方法来获得它而不使用它?
【问题讨论】:
-
您在编辑中提供的内容对我来说看起来很棒。
'='不是第二个参数,但->where('user_works.active', 1)应该可以正常工作。 -
@Deefour 好吧,还有其他参数,更大或更小等等。我只是复制粘贴。我想知道的是,我可以动态捕获表名,而不是让表名公开保护。这将是我需要放置原始表名的唯一地方,这感觉不对。
标签: laravel laravel-4 filtering eloquent pivot-table