使用与 Laravel 中的数据库列名称不同的 html 输入名称
P粉818125805
P粉818125805 2024-01-16 12:40:25
0
2
363

如何使用与我想要将此输入数据保存到的列名称不同的 html 输入名称

我通常使用这种方法,因为所有 html 输入名称都等于数据库列:

Model::create($request->all());

现在我知道我可以使用这个:

Model::create([
'name' => $request->name,
'feild' = > $request=>value,
etc.
]);

但是我有很多值,我不想一遍又一遍地重写它,那么有没有一种方法可以将 $request->all() 与第二种方法结合起来?

P粉818125805
P粉818125805

全部回复(2)
P粉627027031

我发现PHP array_merge()函数可以使用如下所示:

Model::create(array_merge($request->all(),['DB fieldName' => $newValue]));
P粉731977554

一种方法是使用 https://laravel.com /docs/9.x/collections#method-merge merge() 添加字段,并使用 https://laravel.com/docs/9.x/collections#method-only 仅返回要添加到模型中的字段,或 https://laravel.com/docs/9.x/collections#method-except 除外() 求逆

$request->merge([
  'new_column_name' => $the_value_you_want_to_use,
  'old_column_name' => the_value_you_donot_want
]);
$request->only('new_column_name')

// or

$request->except('old_column_name')
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!