在yii中编辑特定记录

时间:2014-03-31 11:54:28

标签: php yii yii-widgets

我的项目中有一个视图部分,并使用CGridView列出表中的所有数据,在网格中也有一个编辑和删除选项来编辑和删除特定的行。

我遇到了编辑部分。我正在研究如何在editjob.php中显示特定的行数据,我做了一些事情,但没有用。我的代码如下,

在我的视图作业部分中使用CgridView,

  'buttons' =>array('update'=>array(

     'label'=>'edit',
     'url'=>'Yii::app()->controller->createUrl("UpdateJob",array("id"=>$data["id"]))',

   ))

在Model UpdateJob中:

public function edit()
{

 $criteria=new CDbCriteria;

 $criteria->find('id','Admin',true);

 return new CActiveDataProvider('viewjob', array(
    'criteria'=>$criteria,
   // 'sort'=>array(
       // 'defaultOrder'=>'key_skills ASC',
   // ),
));
控制器中的

public function actionUpdateJob()
{ 

     if(isset($_GET['id']))
    {
        $id=$_GET['id'];
    }

     $model = new UpdateJob('edit');
     $params = array('model' => $model,'id' => $id  //passing the id like this
    );



    $this->render('update', $params);
}

最后在视图中写了类似的东西,但显示错误

   <div class="row">
        <?php echo $form->labelEx($model,'Company Name'); ?>
        <?php echo Chtml::textField('posted_by',UpdateJob::model()->FindByPk($model->id)->posted_by);  ?>
        <?php echo $form->error($model,'posted_by'); ?>
    </div>
我正在走上正轨。

1 个答案:

答案 0 :(得分:0)

您正在加载新模型而不是获取现有模型。替换此行:

$model = new UpdateJob('edit');

通过这一行:

$model = UpdateJob::model()->findByPk($id);

要保存数据,请执行以下操作:

if(isset($_POST['UpdateJob'])) {
    $model->scenario='edit';
    $model->attributes=$_POST['UpdateJob'];
    if($model->save())
        $this->redirect(array('admin');
}