首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Laravel - Model从另一个模型获取数据

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

Stack Overflow用户
提问于 2018-06-17 00:28:29
回答 2查看 4.5K关注 0票数 0

我对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“。所以:

  1. 我有这个文档的表格。它可以设置除了颜色之外的所有属性(这样它就可以创建与档案共享的协议)
  2. I提交表单,然后检查是否存在具有该协议的档案(即不是primary_key)
  3. If )。我找到具有该协议的档案,我将该档案的颜色插入到文档模型中。

我想知道我应该如何实现第二步。

目前,我已经在DocumentController中写道:

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

然后

$document -> color;

但我觉得这不是办法。谢谢你的建议

EN

回答 2

Stack Overflow用户

发布于 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_documentid_dossier不是一种好的做法。最好将这些更改为id,否则您当前的关系将无法工作。默认情况下,初始关系假设id为主键。如果要使用不同主键名称,则需要在关系中将该键名作为第二个参数传递。

$this->hasMany('App\Comment', 'foreign_key', 'local_key'); 

https://laravel.com/docs/5.6/eloquent-relationships#one-to-many

票数 2
EN

Stack Overflow用户

发布于 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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50889672

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档