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

标签 php laravel controller laravel-5.2

我有两个表:

 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/

相关文章:

php - 为什么 CakePHP 中的创建函数试图保存以前的条目?导致重复输入错误

mysql - 是否有替代 LIKE 的方法来使用 Laravel 获取列中另一个字符串中的字符串

laravel - npm 安装在 laradock 上不工作

ruby-on-rails - 运行 RSpec 测试时出现 UrlGenerationError

java - 在 Controller 内创建的 header 的单元测试

php - 关联数组中 undefined index 和 MySQL 语法错误

php - 在 where 子句中找不到列

php - Slim framework v3 路由条件

javascript - 如何在 Vue 中同时绑定(bind)和发出数据?

ruby-on-rails - 在一个 View 表中对多个模型进行排序