Yii框架,提交表单后,文本字段不会在数据库中更新

Mah*_*kia 1 mysql yii

我对MVC和Yii框架很新,因此很有可能我的问题非常愚蠢.如果是这样,请提前接受我的预测.

我希望在我的网站管理部分中有一个表单,用户可以在其中发布一些内容.我按照示例博客的教程,但似乎添加到数据库中定义为文本的字段(我的表单中的textarea)的内容在提交表单后没有得到更新(其他一切正常).这是我的表的sql语句:

CREATE TABLE `tbl_show` (
   `id` bigint(20) NOT NULL AUTO_INCREMENT,
   `presentation` text,
    PRIMARY KEY (`id`),
    KEY `fk_tbl_show_tbl_season1` (`tbl_season_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=2 ;
Run Code Online (Sandbox Code Playgroud)

我使用Gii制作我的模型和CRUD,我只在这里添加可能相关的部分:

在我的控制器上:

    public function actionCreate()
{
    $model=new Show;

    if(isset($_POST['Show']))
    {
        $model->attributes=$_POST['Show'];
        if($model->save())
                    {
                        $this->redirect(array('view','id'=>$model->id));
                    }   
    }
    $this->render('create',array(
        'model'=>$model,
    ));
Run Code Online (Sandbox Code Playgroud)

和我的_form.php:

<div class="form">

 <?php $form=$this->beginWidget('CActiveForm', array(
 'id'=>'show-form',
 'enableAjaxValidation'=>false,
  )); ?>

<?php echo $form->errorSummary($model); ?>

    <div class="row">
    <?php echo $form->labelEx($model,'presentation'); ?>
    <?php echo $form->textArea($model,'presentation',array('rows'=>6, 'cols'=>50)); ?>
    <?php echo $form->error($model,'presentation'); ?>
</div>

<div class="row buttons">
    <?php echo CHtml::submitButton($model->isNewRecord ? 'Create' : 'Save'); ?>
</div>

    <?php $this->endWidget(); ?>

    </div><!-- form -->
Run Code Online (Sandbox Code Playgroud)

型号规则:

return array(
    array('id, presentation', 'safe', 'on'=>'search'),
);
Run Code Online (Sandbox Code Playgroud)

我不明白为什么只有文本内容不会更新,它们在数据库中显示为null.

提前谢谢,干杯,Mahsa

dIn*_*0nG 6

你必须使属性安全.将其添加到Show模型验证规则中

array('presentation','safe')
Run Code Online (Sandbox Code Playgroud)