我有以下模式:
public function up()
{
Schema::create('messages', function(Blueprint $table) {
$table->increments('id');
$table->mediumText('subject');
$table->text('message');
$table->boolean('draft');
$table->integer('sender_id')->unsigned();
$table->softDeletes();
$table->timestamps();
$table->foreign('sender_id')->references('id')->on('users')->onUpdate('cascade');
});
Schema::create('message_assets', function(Blueprint $table) {
$table->increments('id');
$table->integer('message_id')->unsigned();
$table->string('filename', 255);
$table->softDeletes();
$table->foreign('message_id')->references('id')->on('messages')->onUpdate('cascade');
});
Schema::create('message_users', function(Blueprint $table) {
$table->increments('id');
$table->integer('message_id')->unsigned();
$table->integer('user_id')->unsigned();
$table->integer('read')->default(0);
$table->string('folder', 255)->nullable();
$table->softDeletes();
$table->foreign('message_id')->references('id')->on('messages')->onUpdate('cascade');
$table->foreign('user_id')->references('id')->on('users')->onUpdate('cascade');
});
}我想要做的是,当用户查看消息时,将pivot表中的read列更新为true。我已经确定了控制器如何从枢轴获取相关记录,并只更新read字段。
下面是我们的关系:
public function to()
{
return $this->belongsToMany('SeriousJelly\Modules\Users\Models\User', 'message_users', 'message_id', 'user_id');
}发布于 2015-05-31 02:45:32
我有点不清楚你到底想要什么。一个小小的控制器代码可能会很好地看到您已经尝试了什么和您正在尝试做什么。
尽管如此,这可能会奏效。
$message->to()->updateExistingPivot($user_id, ['read'=> 1]);使用to有点模棱两可,假设这是在Message模型上的话,我可能会使用user使其更加清晰。
文档有一些好的信息。
每个评论的更新
下面的代码在Laravel 5中工作,但我不确定4.2。
$message->to()->sync([$user_id => ['read'=> 1]], false);https://stackoverflow.com/questions/30552249
复制相似问题