【发布时间】:2018-01-07 16:25:00
【问题描述】:
我尝试更新特定项目,但出现错误“在 null 上调用成员函数 update()”。 我之前尝试用 ->insert($data) 更改 ->update($data) 并且它可以工作。
控制器:
public function update(Request $request, $id)
{
$this -> validate($request, array(
'gamename' => 'required|min:3',
'price' => 'required|int|min:1',
'genre' => 'required',
'releaseddate' => 'required|date',
'picture' => 'required|mimes:jpeg,jpg,png,gif'
));
$gamename = $request->input('gamename');
$genre = $request->input('genre');
$price = $request->input('price');
$releaseddate = Carbon::parse($request->input('releaseddate'));
$picture = $request->file('picture')->getClientOriginalName();
$data=array('gamename' => $gamename, 'genre'=>$genre, 'price'=>$price,'releaseddate'=>$releaseddate,'picture'=>$picture );
DB::table('games')->join('genres', 'games.genreid', '=', 'genres.genreid')->find($id)->update($data);
return redirect('managegame');
}
查看:
<form action="/update/{id}" method="post" id="registerform" enctype="multipart/form-data">
<div class="errorpop{{ $errors->has('genre') ? ' has-error' : '' }}">
<label for="genre" class="">Genre</label>
<div class="">
@foreach($genres as $genre)
<option value="{{ $genre->genreid }}">{{ $genre->genre }}</option>
@endforeach
@if ($errors->has('genre'))
<span class="help-block">
<strong>{{ $errors->first('genre') }}</strong>
</span>
@endif
</div>
</div>
【问题讨论】:
-
获取我点击编辑的游戏ID ||我得到了与我使用 {{ $id = $_SESSION['id'] }} @AlexeyMezenin 相同的结果
-
那么,这给了你一个对象然后
dd(DB::table('games')->find($id))?而不是null?如果是,请执行此操作DB::table('games')->where('id', $id)->update($data); -
是的,这不是
null,我已经尝试过您的答案。它没有显示任何错误,但它只是刷新编辑页面(它应该是重定向:视图)而不更新数据 -
听起来像验证重定向回来,尝试删除验证。游戏会更新吗?
-
DB::table('games')->where('id',$id)->update($data);应该可以工作,对我来说工作正常,刚刚测试过
标签: php mysql database laravel