Laravel试图在同一个表中获得非对象,关系的属性

时间:2016-07-07 07:06:58

标签: php laravel eloquent laravel-5.1

我有一个用户模型如下:

<?php

namespace App;

use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Foundation\Auth\Access\Authorizable;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\Access\Authorizable as AuthorizableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;

class User extends Model implements AuthenticatableContract,
                                    AuthorizableContract,
                                    CanResetPasswordContract
{
    use Authenticatable, Authorizable, CanResetPassword;

    /**
     * The database table used by the model.
     *
     * @var string
     */
    protected $table = 'users';
    public function recruits()
    {
        return $this->hasMany('App\User','recruiters_id');
    }
    public function recruiter()
    {
        return $this->belongsTo('App\User','recruiters_id');
    }
}

'users'表中有一个'recruiters_id'字段,其中设置了:

public function up()
    {
        Schema::table('users', function (Blueprint $table) {
            $table->foreign('recruiters_id')->references('id')->on('users');
        });
    }

因此,用户可以招募其他用户。但是,当我尝试像{{$ user-&gt; recruiter-&gt; id()}}这样的东西时,我得到了“试图获取非对象的属性”错误

如果我做{{print_r($ user-&gt; recruiter)}}而是我得到下面的输出,它看起来像一个对象(至少我的缺乏经验的眼睛,虽然它看起来像“对象”是重复了几次,即使我只使用print_r一次):

App\User Object ( [table:protected] => users [fillable:protected] => Array ( [0] => review_count [1] => review_sum [2] => review_avg [3] => display_name [4] => business_name [5] => setting1 [6] => referrer_id [7] => referrer_margin [8] => gender [9] => age [10] => title [11] => points [12] => credits [13] => bankacct_nr [14] => bankacct_name [15] => bsb [16] => save_payment [17] => newsletter [18] => first_name [19] => last_name [20] => phone [21] => email [22] => password [23] => subject [24] => credentials [25] => margin [26] => user_type [27] => url [28] => questions [29] => form_subject [30] => postcode [31] => recruiters_id [32] => internal_notes ) [hidden:protected] => Array ( [0] => password [1] => remember_token ) [connection:protected] => [primaryKey:protected] => id [perPage:protected] => 15 [incrementing] => 1 [timestamps] => 1 [attributes:protected] => Array ( [id] => 240 [first_name] => Jane [last_name] => Recruit [title] => [phone] => [email] => i@recruit.com [user_type] => recruiter [margin] => 0.00 [credentials] => [password] => $2y$10$eTSX9vRGFr5eupAL/kyexeARVDjT.M/7xE2Yp.6PMTuH/dOsFd6QS [remember_token] => [created_at] => 2016-07-06 15:19:23 [updated_at] => 2016-07-06 15:19:23 [status] => [url] => [newsletter] => 0 [postcode] => [form_subjects] => [questions] => [save_payment] => 0 [bsb] => [bankacct_nr] => [bankacct_name] => [points] => 0 [credits] => 0 [gender] => [age] => 0 [referrer_id] => [referrer_margin] => 0.00 [setting1] => [business_name] => [display_name] => i recruit [following] => [followers] => [belts_id] => [recruiters_id] => [internal_notes] => [review_count] => 0 [review_sum] => 0 [review_avg] => 0.00 ) [original:protected] => Array ( [id] => 240 [first_name] => Jane [last_name] => Recruit [title] => [phone] => [email] => i@recruit.com [user_type] => recruiter [margin] => 0.00 [credentials] => [password] => $2y$10$eTSX9vRGFr5eupAL/kyexeARVDjT.M/7xE2Yp.6PMTuH/dOsFd6QS [remember_token] => [created_at] => 2016-07-06 15:19:23 [updated_at] => 2016-07-06 15:19:23 [status] => [url] => [newsletter] => 0 [postcode] => [form_subjects] => [questions] => [save_payment] => 0 [bsb] => [bankacct_nr] => [bankacct_name] => [points] => 0 [credits] => 0 [gender] => [age] => 0 [referrer_id] => [referrer_margin] => 0.00 [setting1] => [business_name] => [display_name] => i recruit [following] => [followers] => [belts_id] => [recruiters_id] => [internal_notes] => [review_count] => 0 [review_sum] => 0 [review_avg] => 0.00 ) [relations:protected] => Array ( ) [visible:protected] => Array ( ) [appends:protected] => Array ( ) [guarded:protected] => Array ( [0] => * ) [dates:protected] => Array ( ) [dateFormat:protected] => [casts:protected] => Array ( ) [touches:protected] => Array ( ) [observables:protected] => Array ( ) [with:protected] => Array ( ) [morphClass:protected] => [exists] => 1 [wasRecentlyCreated] => ) 1 

这是我第一次在同一张桌子中设置Eloquent关系,所以也许我在那里犯了一些错误。使用Laravel 5.1

非常感谢任何建议,提前谢谢

1 个答案:

答案 0 :(得分:2)

如果没有完整的迁移,我会说问题就在这里

public function recruits()
{
    return $this->hasMany('App\User','recruiters_id');
}
public function recruiter()
{
    return $this->belongsTo('App\User','recruiters_id');
}

对于这两种关系,你把招聘人员作为外键,即使它是招聘人员。

对于hasMany你应该

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

belongsTo

相同
return $this->belongsTo('App\User', 'foreign_key', 'other_key');

因此

public function recruits()
{
    return $this->hasMany('App\User','recruiters_id', 'id');
}
public function recruiter()
{
    return $this->belongsTo('App\User');
}

应该是您正在寻找的(如果您的迁移中正确定义了招聘人员)