0

したがって、検索で選択フィールドに日付を dd/mm/yy として表示したいのですが、私のデータベースは yy-mm-dd に設定されているので、データベースで使用するために変換したいのですが、それでも dd/mm/yy を表示します選択フィールドのユーザーに対して。

モデル:

public function search($auditCriteria=null)
{
    // Warning: Please modify the following code to remove attributes that
    // should not be searched.

    $criteria=new CDbCriteria;
            $cni = new ContractNoteItem();

            $criteria->with =array('contractNoteItems'=>array('select'=>'{{contractNoteItems}}.*','joinType'=>'LEFT OUTER JOIN', ), );


            if(isset($_GET['cni_client_account_no']) && $_GET['cni_client_account_no']!=0 && $_GET['cni_client_account_no']!=""){
              //  echo 2;
                if(isset($_GET['cni_portfolio_id2']) && $_GET['cni_portfolio_id2']!=0 && $_GET['cni_portfolio_id2']!="")
                {
             //      echo 3;
                    $criteria->join = 'RIGHT JOIN ial_contract_note_item ON ial_contract_note_item.cni_contract_note_id=t.id';
                    $criteria->condition = 'ial_contract_note_item.cni_contract_note_id=t.id';
                    $criteria->compare('cni_contract_note_id',$this->id);
                    $criteria->compare('ial_contract_note_item.cni_portfolio_id',$_GET['cni_portfolio_id2']);
                }else{
               //     echo 4;
                    $criteria->join = 'RIGHT JOIN ial_contract_note_item ON ial_contract_note_item.cni_contract_note_id=t.id';
                    $criteria->condition = 'ial_contract_note_item.cni_contract_note_id=t.id';
                    $criteria->compare('cni_contract_note_id',$this->id);
                    $criteria->compare('ial_contract_note_item.cni_client_account_no',$_GET['cni_client_account_no']);
                }
             //   echo 5;
            }
           // echo 6, 

    $criteria->compare('id',$this->id,true);
    $criteria->compare('cn_fund_house_id',$this->cn_fund_house_id,true);
    $criteria->compare('cn_investment_date',$this->cn_investment_date,true);
    $criteria->compare('cn_settlement_date',$this->cn_settlement_date,true);
            $criteria->compare('transaction_id',$this->transaction_id,true);
            $criteria->compare('sub_transaction_id',$this->sub_transaction_id,true);
            $criteria->compare('counter_party_trans_ref',$this->counter_party_trans_ref,true);
            $criteria->compare('t.modified_by',$this->modified_by,true);
          //  $criteria->compare('ial_contract_note_item.cni_portfolio_id',$this->cni_portfolio_id,true);


            if($auditCriteria != null && $auditCriteria)
            {
                //$criteria->compare('actual',1);
                $criteria->compare('t.pending',1);
            }

            if(!$auditCriteria)
            {               
                $criteria->compare('t.actual',1);
                $criteria->compare('t.pending',0);
            }

    return new CActiveDataProvider($this, array(
        'criteria'=>$criteria,
    ));
}

では、これをどのように正確に進める必要がありますか?altField で altFormat を試してみましたが、日付形式が完全に上書きされ、データベースは実際の dateFormat を認識しません。関数の前後にある必要があることはわかっていますが、ロードされていないようです

4

1 に答える 1

0

モデルクラスでセッターとゲッターを作成できます

public function setDate($value)
{
  $dt=DateTime.createFromFormat('d/m/Y',$value);
  $this->your_date=$dt->format('Y-m-d');
}
public function getDate()
{
  $dt=DateTime.createFromFormat('Y-m-d',$this->your_date);
  return $dt->format('d/m/Y');
}

そして、ウィジェットがモデルのプロパティ 'Date' (set/get の後の単語) を使用するようにします。

変数名を好みに合わせて調整する

于 2013-08-30T15:35:58.573 に答える