我正在使用laravel 5.2,我在创建用户时遇到此错误。
调用未定义的方法Illuminate \ Database \ Query \ Builder :: associate()
这是我的User.php
namespace App;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
protected $fillable = [
'name', 'email', 'password', 'role_id'
];
protected $hidden = [
'password', 'remember_token',
];
public function role()
{
return $this->hasOne('App\Role');
}
}
my role.php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Role extends Model
{
protected $table = "roles";
protected $fillable = [
'name','description'
];
public function user()
{
return $this->belongsTo('App\User');
}
}
这是我使用的迁移
public function up()
{
Schema::create('roles', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->string('description');
});
Schema::create('users', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->string('email')->unique();
$table->string('password');
$table->integer('role_id')->unsigned();
$table->foreign('role_id')->references('id')->on('roles');
$table->rememberToken();
$table->timestamps();
});
}
这是我正在使用的控制器代码
$role = Role::find(1);
$user = new User();
$user->name = "Admin";
$user->email = "email@gmail.com";
$user->password = bcrypt("password");
$user->role()->associate($role);
$user->save();
当我运行此代码时,我得到了 “调用未定义的方法Illuminate \ Database \ Query \ Builder :: associate()” 错误
让我知道我的代码有什么问题。
答案 0 :(得分:1)
associate()
函数用于更新belongsTo()
关系。您的role()
关系是hasOne()
,这就是该方法不存在的原因。
答案 1 :(得分:0)
我认为您可以使用associate()
方法关联角色,然后更改您的关系,如下所示:
return $this->hasOne('App\Role');
替换为
return $this->belongsTo('App\Role');
和
return $this->belongsTo('App\User');
替换为
return $this->hasOne('App\User');
希望这对你有所帮助!