yii比较模型中的日期和时间

时间:2012-08-24 04:26:04

标签: php yii

我有规则模型

public function rules() {
        return array(
            array('user_id, name, start_date, timezones, start_hours, return_date, return_hours, location_start, location_end, trip_activity, trip_mean, status', 'required'),
            array('user_id, return_hours, sign_off, saved, advise, time_notification, status', 'numerical', 'integerOnly'=>true),
            array('name, going_with, start_hours, location_start, location_end, location_return, trip_activity, trip_mean', 'length', 'max'=>255),
            array('created, modified, advise, notify_best_friend, notify_now, notify_returning, send_notification, sign_off', 'safe'),
            array('going_with, location_return, time_notification, created, modified', 'default', 'setOnEmpty' => true, 'value' => null),
            array('id, user_id, name, going_with, start_date, start_hours, return_date, return_hours, location_start, location_end, location_return, trip_activity, trip_mean, saved, advise, time_notification, status, created, modified', 'safe', 'on'=>'search'),
            array(
                  'return_date',
                  'compare',
                  'compareAttribute'=>'start_date',
                  'operator'=>'>=', 
                  'allowEmpty'=>false , 
                  'message'=>'{attribute} must be greater than "{compareValue}".'
                ),

            array(
                  'return_hours',
                  'compare',
                  'compareAttribute'=>'start_hours',
                  'operator'=>'>', 
                  'allowEmpty'=>false , 
                  'message'=>'{attribute} must be greater than "{compareValue}".'
                ),
            );
    }

我想比较日期和时间......
如果:'return_date'> ='start_date'......没关系。
如果'return_date'=='start_date',那么'return_hours> 'start_hours'但是上面的规则我无法比较它们。
什么是解决方案?谢谢!

1 个答案:

答案 0 :(得分:4)

您可以使用自定义验证器来实现此目的。

public function comparedates($attribute,$params)
        {
            $message=Yii::t('yii','{attribute} must be greater than "{compareValue}".');
            if(CDateTimeParser::parse($this->return_date, "yyyy-MM-dd") < CDateTimeParser::parse($this->start_date, "yyyy-MM-dd"))
            {
                $params=array('{attribute}'=>$this->getAttributeLabel('return_date'),'{compareValue}'=>$this->getAttributeLabel('start_date'));
                $this->addError($attribute,strtr($message,$params));
            }
            else if(CDateTimeParser::parse($this->return_date, "yyyy-MM-dd") === CDateTimeParser::parse($this->start_date, "yyyy-MM-dd"))
            {
                if(CDateTimeParser::parse($this->return_hours, "hh") < CDateTimeParser::parse($this->start_hours, "hh")//change hh according to the format of return_hours and start_hours
                {   
                    $params=array('{attribute}'=>$this->getAttributeLabel('return_hours'),'{compareValue}'=>$this->getAttributeLabel('start_hours'));
                    $this->addError('return_hours',strtr($message,$params));                
                }
            }
        }

在您的规则中

public function rules() {
return array(
 //your previous rules 
     array('return_date','comparedates'),
    );

}

请务必根据patternhh

的格式,从return_hours更改start_hours的{​​{1}}参数