Larve 6 l“从空值创建默认对象”

问题描述 投票:0回答:1

[这里,我设置了带有laravel,vuetify和vue的CRUD表。我可以成功创建和读取数据库中的数据。但是,由于某种原因,我的更新和删除无法正常工作。我收到类似这样的错误:

{消息:“从空值创建默认对象”,异常:“ ErrorException”,…}异常:“ ErrorException”文件:“ C:\ WinNMP \ WWW \ chillibiz \ app \ Sys \ Http \ Controllers \ StageController.php”线:53消息:“从空值创建默认对象”跟踪:[{文件:“ C:\ WinNMP \ WWW \ chillibiz \ app \ Sys \ Http \ Controllers \ StageController.php”,行:53,…},…]

我的代码在这里:

StageController.php

<?php


namespace App\Sys\Http\Controllers;

use App\Http\Controllers\Controller;

use Illuminate\Http\Request;

use Illuminate\Support\Str;

use App\Sys\Model\Stage;

class StageController extends Controller
{

    public function index(Request $request)
    {  
        $per_page = $request->per_page ? $request->per_page : 5;
        $sort_by = $request->sort_by;
        $order_by = $request->order_by;
        return response()->json(['stages' => Stage::orderBy($sort_by, $order_by)->paginate($per_page)],200);
    }

    public function store(Request $request)
    {
        $uuid = Str::uuid()->toString();
        $stage= Stage::create([
            'id' => $uuid,
            'code' =>$request->code,
            'name' =>$request->name,
            'description' =>$request->description,
        ]);
        return response()->json(['stage'=>$stage],200);
    }


    public function show($id)                                                                                                                                                           
    {
        $stages = Stage::where('code','LIKE', "%$id%")->orWhere('name','LIKE', "%$id%")->orWhere('description', 'LIKE', "%$id%")->paginate();
        return response()->json(['stages' => $stages],200);
    }



    public function update(Request $request, $id)
    {


       $stage = Stage::find($id);


       $stage->code  = $request->code; //line 53
       $stage->name  = $request->name;
       $stage->description  = $request->description;


       $stage->save(); 
       return response()->json(['stage'=>$stage], 200);
    }

    public function destroy($id)
    {
        $stage = Stage::where('id', $id)->delete();
        return  response()->json(['stage'=> $stage],200);
    }



    public function deleteAll(Request $request){
        Stage::whereIn('id', $request->stages)->delete();
        return response()->json(['message', 'Records Deleted Successfully'], 200);
    }
}

Stage.php

<?php

namespace App\Sys\Model;

use Illuminate\Database\Eloquent\Model;

class Stage extends Model
{
    protected $guarded = [];
}
laravel controller edit
1个回答
0
投票

我刚刚发现他们您使用uuid作为id不会递增。那为什么你会得到这样的错误:

要解决您的问题,您需要将字段添加到模型中;

<?php

namespace App\Sys\Model;

use Illuminate\Database\Eloquent\Model;

class Stage extends Model
{
    public $incrementing = false;
    protected $keyType = 'string';
    protected $guarded = [];

}

我希望这次您能解决您的问题。快乐的编码。编辑您可以阅读docs for more info

© www.soinside.com 2019 - 2024. All rights reserved.