我对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“。内部档案是唯一属性,文档内部可以重复,因为更多的文档可能是具有协议的相同档案的一部分。
假设我必须创建一个文档模型。但是我需要一个已经存在于档案中的属性"color“。所以:
我想知道我应该如何实现第二步。
目前,我已经在DocumentController中写道:
$document = Dossier::where('protocol', '=', $request->protocol)->first();
然后
$document -> color;
但我觉得这不是办法。谢谢你的建议
发布于 2018-06-17 00:48:25
如果协议匹配,我认为你想在档案表中的文档中插入颜色。如果我没理解错的话,你可以这样写。
$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
,否则您当前的关系将无法工作。默认情况下,初始关系假设id
为主键。如果要使用不同主键名称,则需要在关系中将该键名作为第二个参数传递。
$this->hasMany('App\Comment', 'foreign_key', 'local_key');
https://laravel.com/docs/5.6/eloquent-relationships#one-to-many
发布于 2018-06-17 03:09:38
有很多种方法来编写关系代码,一种是像rkj所说的anad U一样。另一个我个人更喜欢的是
$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
https://stackoverflow.com/questions/50889672
复制相似问题