5

我有一个表,其中的列for_date按数据库中的整数类型保存。为了以for_dateDateTime 格式显示,我使用了带有代码的 ActiveForm:

<?= $form->field($model, 'for_date')->textInput([
    'class' => 'form-control datepicker',
    'value' => $model->for_date ? date(Yii::$app->params['dateFormat'], $model->for_date) : date(Yii::$app->params['dateFormat'], time()),
    'placeholder' => 'Time'])
    ->label('Attendance Date') ?>

但是当我创建和保存时,Yii 通知了This field must be integer

在模型文件中,我有以下 2 个函数在验证之前进行转换,但它仍然是错误的。

public function beforeValidate(){
    if(!is_int($this->for_date)){
        $this->for_date = strtotime($this->for_date);
        $this->for_date = date('d/M/Y', $this->for_date);
    }
    return parent::beforeValidate();
}

public function afterFind(){
    $this->for_date = \Yii::t('app', Yii::$app->formatter->asDate($this->for_date));
    $this->for_date = date('d/M/Y', $this->for_date);
    return parent::afterFind();
}

我怎样才能正确地用整数保存到数据库中?

4

2 回答 2

0

我找到了解决方案。在模型搜索(我的情况是AttendanceSearch.php)中,查找规则功能并for_date从行必须移动integer到下面的行safe

我的代码:

public function rules()
    {
        return [
            [['id', 'user_id', 'project_id', 'commit_time', 'workload_type'], 'integer'],
            [['comment', 'for_date'], 'safe'],
        ];
    }
于 2015-10-22T08:19:14.380 回答
0

根据您的代码在运行for_date后仍然是日期格式,beforeValidate因为该行:

$this->for_date = date('d/M/Y', $this->for_date);

删除此行,它应该可以工作。

但是,您仍然会遇到问题,例如日期格式或有人输入无效日期,例如30/02/2015

我建议创建一个单独的属性,例如for_date_display并为此添加一个日期规则。然后beforeSave将此日期转换为时间戳并设置for_date为该值,如下所示:

public $for_date_display;
...

public function afterFind() {
    $this->for_date_display = \Yii::t('app', Yii::$app->formatter->asDate($this->for_date))
}

public function beforeSave($insert = true) {
    $this->for_date = strtotime($this->for_date_display);
    return parent::beforeSave($insert);
}
于 2015-10-13T08:54:01.477 回答