Laravel 5.3更新记录。仅更新已更改的记录并保留未更改的记录

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Laravel 5.3更新记录。仅更新已更改的记录并保留未更改的记录相关的知识,希望对你有一定的参考价值。

enter image description hereenter image description here我想更新一个配置文件,当我更新记录时,我没有更改的旧数据也会更新。

我想只更新那些已更改的值。不应更新未更改的值。

路线:

Route::post('/profile/settings/{user}', 'AdminuserController@UpdateProfileSettings')->name('profile.settings');

控制器方法:

 public function UpdateProfileSettings(Request $request, User $user)
{

    if (auth()->user()->id == $user->id) {

        $user->update([
            'name' => $request->name,
            'qualification' => $request->qualification,
            'institute' => $request->institute,
            'gender' => $request->gender,
            'speciality' => $request->speciality,
            'address' => $request->address,
        ]);

        return redirect()->back();
    } else {
        abort(403, "Unauthorized");
    }
}
答案

您可以尝试以下方法

$name = $request->input('name', $user->name);

对于laravel 5.4:还可以确保在TrimStrings中找到应用程序的全局中间件堆栈中的ConvertEmptyStringsToNullAppHttpKernel中间件

对于laravel 5.3,您可以手动将这些中间件添加到您的项目中。添加TrimgStrings说明here

添加ConvertEmptyStringsToNull将遵循相同的步骤..

创建一个新文件ConvertEmptyStringsToNull.php

<?php
namespace AppHttpMiddleware;
class ConvertEmptyStringsToNull extends TransformsRequest
{
    /**
     * Transform the given value.
     *
     * @param  string  $key
     * @param  mixed  $value
     * @return mixed
     */
    protected function transform($key, $value)
    {
        return is_string($value) && $value === '' ? null : $value;
    }
}
  1. 通过添加到您的AppHttpKernel.php将中间件注册为全局 protected $middleware = [ IlluminateFoundationHttpMiddlewarCheckForMaintenanceMode::class, AppHttpMiddlewareTransformsRequest::class, AppHttpMiddlewareTrimStrings::class, AppHttpMiddlewareConvertEmptyStringsToNull::class, ];

以上是关于Laravel 5.3更新记录。仅更新已更改的记录并保留未更改的记录的主要内容,如果未能解决你的问题,请参考以下文章

如何设置此数据的更新 - Laravel/Lumen

更新记录:如何检查新文件是否已上传PHP

使用ajax更新数据库记录的Laravel刷新页面

BigQuery - 使用更改/删除的记录更新表

Laravel 更新语法 - 使用数组更新记录

更改更新核心数据属性的删除方法