我对laravel很新,我正在努力理解雄辩的关系。 我已经阅读了一些答案和文档,但我没有找到一个类似于我的简单案例。
我有两个与一对多关系的模型。
文档模型
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Document extends Model
{
public function dossiers()
{
return $this->belongsTo('App\Dossier');
}
protected $table = 'documents';
protected $primaryKey = 'id_document';
}
档案模型
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Dossier extends Model
{
public function documents()
{
return $this->hasMany('App\Document');
}
protected $table = 'dossiers';
protected $primaryKey = 'id_dossier';
}
因此两个表中都有一个属性“protocol”。 Inside Dossier是一个独特的属性,Document内部可以重复,因为更多的文档可能是该协议的同一档案的一部分。
我们假设我必须创建一个文档模型。但我需要一个已存在于档案中的属性“颜色”。 这样:
如果我找到一个带有该协议的档案,我就拿了那个档案的颜色 我将它插入文档模型。
我想知道如何实施第二步。
目前我在DocumentController中写道:
$document = Dossier::where('protocol', '=', $request->protocol)->first();
然后
$document -> color;
但是我觉得这不是那样的。 感谢您的任何建议
答案 0 :(得分:2)
如果协议匹配,我想你想从档案表中插入文件中的颜色。如果我理解正确,那么你可以这样写。
$dossier = Dossier::where('protocol', '=', $request->protocol)->first();
$color = ($dossier) ? $dossier->color: 'defaultColor';
现在在您的创建文档中
$document -> create([
'color' => $color,
... other form data here
]);
注意:将primary key
字段用作id_document
或id_dossier
是不太好的做法。最好将这些更改为id
,否则您当前的关系将无效。默认情况下,laravel关系假定id
为主键。如果要使用不同的主键名称,则需要将关键字名称作为第二个参数传递给。
$this->hasMany('App\Comment', 'foreign_key', 'local_key');
https://laravel.com/docs/5.6/eloquent-relationships#one-to-many
答案 1 :(得分:0)
有很多方法可以编写关系代码,其中一个就像rkj所说的anad你也做过。 我个人更喜欢的另一个是
$this->hasManny(Comment::class,'foreign_key', 'local_key'); //This is only if you are not following laravel standard table syntex.
但是,如果您的本地密钥是id
,而另一个表上的外键是comment_id
。然后你不需要添加外键和主键。你可以这样做
$this->hasManny(Comment::class);
要进行查询,您只需执行此操作
$dossier = Dossier::where('protocol', $request->protocol)->first(); //This will give object
您不需要=
,如果是其他,那么您需要添加它。这样看起来更清洁吧?
然后要显示您只需执行此操作$dossier->color