gpt4 book ai didi

php - 拉维尔 : How to update data in one to one Eloquent relationship

转载 作者:搜寻专家 更新时间:2023-10-31 21:25:50 24 4
gpt4 key购买 nike

我有两个表:

 1. User.
2. Post.

在帖子表中我保存了用户信息。所以当我点击更新时,它应该加载特定的用户数据。它已加载,但是当我单击保存按钮以更新保存时。它显示以下错误。

FatalErrorException in PostController.php line 78: Call to undefined function App\Http\Controllers\fill()

我想我的 postUpdate Controller 有问题。但是我找不到问题。

这是我的用户模型:

<?php

namespace App;

use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{

protected $fillable = [
'name', 'email', 'password',
];


protected $hidden = [
'password', 'remember_token',
];

public function post()
{
return $this->hasOne('App\Post'); //Profile is your profile model
}
}

这是我的帖子模型:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
protected $fillable = [
'first_name', 'middle_name', 'last_name','gender', 'dob','nationality','nid','email','phone_no','about_me'
];
public function user()
{
return $this->belongsTo('App\User'); //Profile is your profile model
}
}

这是我的帖子 Controller :

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Http\Response;
use App\Http\Requests;
use App\Post;
use App\User;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\File;

class PostController extends Controller
{


public function getDashboard()
{
$posts = Post::all();
return view('dashboard',['posts'=>$posts]);
}


public function postCreate(Request $request){
$this->validate($request,[
'first_name'=> 'required|max:120',
'middle_name'=> 'required|max:120',
'last_name' => 'required|max:120',
'gender'=> 'required',
'dob'=>'required',
'nationality'=>'required',
'nid'=>'required',
'email' => 'required|email|unique:users',
'phone_no'=>'required',
'about_me'=>'required',
]);

$post = new Post();
$post->first_name = $request['first_name'];
$post->middle_name = $request['middle_name'];
$post->last_name = $request['last_name'];
$post->gender = $request['gender'];
$post->dob = $request['dob'];
$post->nationality = $request['nationality'];
$post->nid = $request['nid'];
$post->email = $request['email'];
$post->phone_no = $request['phone_no'];
$post->about_me = $request['about_me'];
$message='There was an Error';
if( $request->user()->post()->save($post)){
$message = "Profile Created successfully";
}
return redirect()->route('dashboard')->with(['message' => $message]);

}


public function postUpdate(Request $request)
{
$this->validate($request,[
'first_name'=> 'required|max:120',
'middle_name'=> 'required|max:120',
'last_name' => 'required|max:120',
'gender'=> 'required',
'dob'=>'required',
'nationality'=>'required',
'nid'=>'required',
'email' => 'required|email|unique:users',
'phone_no'=>'required',
'about_me'=>'required',
]);


$request->user()->post()->update(fill($request->all())) ;

return redirect()->route('dashboard');
}



}

最佳答案

在这里,您将获得一组帖子:

$data=Post::all();

但是你需要传递一个数组。尝试将其替换为:

$data = $request->only('first_name', 'middle_name', 'last_name', 'gender', 'dob', 'nationality', 'nid', 'email', 'phone_no', 'about_me');

关于php - 拉维尔 : How to update data in one to one Eloquent relationship,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36369778/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com