繁体   English   中英

Laravel / Eloquent: hasManyThrough question

[英]Laravel / Eloquent : hasManyThrough question

我有 3 个表:合同,ID 为 Contract_User,合同 ID 和用户 ID 用户,ID

当我有合同时,我正在尝试使用 hasManyThrought 来获取用户信息,但是我遇到了麻烦。

可能吗? 谢谢

我同意蒂姆·刘易斯的观点。 我认为这只是一个“简单”的BelongsToMany 根据您的模型的外观,以下是它们可能/应该看起来的示例。

如果您使用的不是默认外键,则需要提供这些列作为额外参数。 您也可以在上面的链接中找到更多相关信息。 希望这可以帮助!

用户.php

/**
 * The contracts that belong to the user.
 */
public function contracts()
{
    return $this->belongsToMany('App\Contract');
}

合同.php

/**
 * The users that belong to the contract.
 */
public function users()
{
    return $this->belongsToMany('App\User');
}

然后在 controller 的某个地方,您可以通过以下方式获得用户的合同:

$user = App\User::find(1);

foreach ($user->contracts as $contract) {
    // $contract->name;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM