Laravel - 模型从另一个模型获取数据

时间:2018-06-16 16:28:29

标签: laravel controller eloquent relationship

我对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内部可以重复,因为更多的文档可能是该协议的同一档案的一部分。

我们假设我必须创建一个文档模型。但我需要一个已存在于档案中的属性“颜色”。 这样:

  1. 我有一份文件表格。这可以设置所有属性除外 颜色(因此它可以创建与Dossier共享的协议)
  2. 我提交表单然后检查是否存在具有该协议的档案 (这不是primary_key)
  3. 如果我找到一个带有该协议的档案,我就拿了那个档案的颜色 我将它插入文档模型。

    我想知道如何实施第二步。

  4. 目前我在DocumentController中写道:

    $document = Dossier::where('protocol', '=', $request->protocol)->first();

    然后

    $document -> color;

    但是我觉得这不是那样的。 感谢您的任何建议

2 个答案:

答案 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_documentid_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