gpt4 book ai didi

laravel - 验证: how to set a field that is not required to 'null' when input is empty

转载 作者:行者123 更新时间:2023-12-04 05:18:02 24 4
gpt4 key购买 nike

我有一个验证规则,如下所示:

$rules = ['target' => 'numeric'];

这不是必填字段。如果在输入中未指定值(即Input::get('target')==''),我希望在数据库中将该字段设置为NULL。

当前,以上规则已通过,并且在没有数字输入的情况下,该规则在数据库中被设置为0。

最好的解决方案是什么?

最佳答案

您只需在调用null之前将null值分配给适当的模型属性,即可在Laravel中将字段设置为save()

if(! Input::get('target') ){
$eloquent_model->target = null;
}

$eloquent_model->save();

但是,如果要在多个模型中插入空值,则可以创建基本模型并由所有其他模型继承。
class BaseModel extends Eloquent {

public static function boot()
{
parent::boot();

static::creating(function($model) {

static::setNullWhenEmpty($model);
return true;

});
}

private static function setNullWhenEmpty($model)
{
foreach ($model->toArray() as $name => $value) {
if (empty($value)) {
$model->{$name} = null;
}
}
}
}

现在,所有空白字段都将自动设置为 null,您无需在保存之前进行检查。

Reference

关于laravel - 验证: how to set a field that is not required to 'null' when input is empty,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24882760/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com