如何从表单更新mysql表行:Laravel 5.8

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

我在Laravel项目上更新一行时遇到问题。表单完美地接收所有必要的信息,但是一旦我点击更新按钮,从表单解析的信息将返回null

我的编辑(表单)文件

@extends('layout')

@section('content')
    <h1 class = "title">Edit Item</h1>

    <form method="post" action="/listings/{{$listing->id}}">

        @method('patch')
        @csrf

        <div>
            <label class="label" for="name">Name of Item</label>
            <div class="control">
                <input required type="text" class="input" name="description" placeholder="Name of Item"  value="{{$listing->title}}" >
            </div>
        </div>

        <div>
            {!! Form::select('lstatus',$lstatus,null) !!}
        </div>

        <div class="field">
            <div class="control">
                <button type="submit" class="button is-link">Update</button>
            </div>
        </div>


    </form>

我的控制器:

    public function edit(listing $listing, lstatus $lstatus)
    {
        $listing = $listing::find($listing->id);
        $lstatus = lstatus::pluck('name','id');
        return view('listings.edit', compact('listing','lstatus'));
    }
    public function update(listing $listing, lstatus $lstatus){



    $listing = listing::find($listing->id);

    $listing->listing_status_id = request('lstatus');
    $listing->title=\request('description');

    return back();

    }

当我点击表单上的提交按钮时,没有任何反应。数据库中没有任何变化,我没有得到任何错误。

预期结果将是要更新的值。

mysql laravel forms edit
1个回答
1
投票

在这种情况下,您可以使用update()方法传递来自请求的所有输入并使用all()方法作为参数,这将保存您在请求中自动发送的所有属性:

$listing = $listing::find($listing->id);
$listing->update($listing->all());

all method:

您还可以使用all方法将所有输入数据检索为数组:

update method

update方法需要一组列和值对,表示应更新的列。

如果您不使用update()方法,则应在进行任何更改后使用save()方法:

 $listing->listing_status_id = request('lstatus');
 $listing->title=\request('description');
 $listing->save();
© www.soinside.com 2019 - 2024. All rights reserved.