关系曾试图获得非对象的属性

时间:2016-10-27 10:36:45

标签: laravel foreign-key-relationship one-to-one table-relationships

我遇到了关系一对一的编辑机制问题&更新条件,所以我有模型Siswa和Telepon,Telepon属于Siswa ...这里是代码

Siswa.php(模特)

class Siswa extends Model
{
protected $table = 'siswa';

protected $fillable = [
    'nisn',
    'nama_siswa',
    'tgl_lahir',
    'jns_klmin'
];

protected $dates = ['tgl_lahir'];

public function getNamaSiswaAttribute($nama_siswa){
    return ucwords($nama_siswa);
}

public function setNamaSiswaAttribute($nama_siswa){
    $this->attributes['nama_siswa']=ucwords($nama_siswa);
}

public function telepon(){
    return $this->hasOne('App\Telepon', 'id_siswa');
}
}

Telepon.php(型号)

class Telepon extends Model
{
protected $table = 'telepon';

protected $primKey = 'id_siswa';

protected $fillable = [
    'id_siswa',
    'no_telepon',
];

public function siswa(){
    return $this->belongsTo('App\Siswa', 'id_siswa');
}
}

编辑和更新功能控制器,如下所示:

public function edit($id){
    $siswa = Siswa::findOrFail($id);
    $siswa->no_telepon = $siswa->telepon->no_telepon;
    return view('siswa.edit', compact('siswa'));
}

public function update(Request $request, $id){
    $siswa = Siswa::findOrFail($id);
    $input = $request->all();

    $validator = Validator::make($input, [
        'nisn'=>'required|string|size:4|unique:siswa,nisn,'.$request->input('id'),
        'nama_siswa'=>'required|string|max:30', 
        'tgl_lahir'=>'required|date',
        'jns_klmin'=>'required|in:L,P',
        'no_telepon'=>'sometimes|numeric|digits_between:10,15|unique:telepon,no_telepon,'.$request->input('id').',id_siswa',
    ]);

    if ($validator->fails()) {
        return redirect('siswa/'.$id.'/edit')->withInput()->withErrors($validator);
    }

    $siswa->update($request->all());

    $telepon = $siswa->telepon;
    $telepon->no_telepon = $request->input('no_telepon');
    $siswa->telepon()->save($telepon);

    return redirect('siswa');
}

我试图在编辑功能中获取非对象错误的属性,行“$ siswa-> no_telepon = $ siswa-> telepon-> no_telepon;”。

当我们在编辑控制器中调用编辑视图时,它将给出一个表单,其中包含以前保存的数据。 no_telepon本身是来自Telepon表的列,而不是Siswa,因此如何显示电话保存的数据以进行编辑是问题所在。仅供参考,创建工作正常,no_telepon数据保存在Telepon表中。那么,这个怎么样?任何帮助表示赞赏。

1 个答案:

答案 0 :(得分:0)

这可能是因为数据库中没有任何'App\Telepon''id_siswa'指向表siswa中记录的ID。

您可以通过以下方式忽略此错误:

public function edit($id){
    $siswa = Siswa::findOrFail($id);
    $siswa->no_telepon = $siswa->telepon ? $siswa->telepon->no_telepon : '';
    return view('siswa.edit', compact('siswa'));
}