使用Giix的Yii控制器中的致命错误

时间:2012-04-23 18:40:28

标签: php yii

所以我继承了一个Yii应用程序,我试图让这个应用程序工作,为管理科学事实表做一个基本的CRUD。我们正在使用Yii和Giix

这是错误: “PHP致命错误:在第58行的/var/www/idtools.org/www/yii/framework/db/ar/CActiveRecord.php中,允许的内存大小为134217728字节(试图分配16个字节)”

更新操作给我们带来了问题。更新在控制器中如下所示:

public function actionUpdate($id) {
    $model = $this->loadModel($id, 'Factsheet');

    if (isset($_POST['Factsheet'])) {
        $model->setAttributes($_POST['Factsheet']);

        if ($model->save()) {
            $this->redirect(array('view', 'id' => $model->factsheetid));
        }
    }

    $this->render('update', array(
            'model' => $model,
            ));
}

视图如下:     

$this->breadcrumbs = array(
    $model->label(2) => array('index'),
    GxHtml::valueEx($model) => array('view', 'id' => GxActiveRecord::extractPkValue($model, true)),
    Yii::t('app', 'Update'),
);

$this->menu = array(
    array('label' => Yii::t('app', 'List') . ' ' . $model->label(2), 'url'=>array('index')),
    array('label' => Yii::t('app', 'Create') . ' ' . $model->label(), 'url'=>array('create')),
    array('label' => Yii::t('app', 'View') . ' ' . $model->label(), 'url'=>array('view', 'id' => GxActiveRecord::extractPkValue($model, true))),
    array('label' => Yii::t('app', 'Manage') . ' ' . $model->label(2), 'url'=>array('admin')),
);
?>

<h1><?php echo Yii::t('app', 'Update') . ' ' . GxHtml::encode($model->label()) . ' ' . GxHtml::encode(GxHtml::valueEx($model)); ?></h1>

<?php
$this->renderPartial('_form', array(
        'model' => $model));
?>

模型(由Giix生成)看起来像:     YII ::进口( 'application.models._base.BaseFactsheet');

class Factsheet extends BaseFactsheet
{
    public static function model($className=__CLASS__) {
        return parent::model($className);
    }
}   

该模型扩展了基础:     抽象类BaseFactsheet扩展了GxActiveRecord {

    public static function model($className=__CLASS__) {
        return parent::model($className);
    }

    public function tableName() {
        return 'factsheet';
    }

    public static function label($n = 1) {
        return Yii::t('app', 'Factsheet|Factsheets', $n);
    }

    public static function representingColumn() {
        return 'name';
    }

    public function rules() {
        return array(
            array('name, toolid', 'required'),
            array('weight', 'numerical', 'integerOnly'=>true),
            array('name, toolid', 'length', 'max'=>255),
            array('inputdate', 'safe'),
            array('weight, inputdate', 'default', 'setOnEmpty' => true, 'value' => null),
            array('factsheetid, name, toolid, weight, inputdate', 'safe', 'on'=>'search'),
        );
    }

    public function relations() {
        return array(
            'tool' => array(self::BELONGS_TO, 'Tool', 'toolid'),
            'factsheetcontents' => array(self::HAS_MANY, 'Factsheetcontent', 'factsheetid'),
            'factsheetimages' => array(self::HAS_MANY, 'Factsheetimages', 'factsheetid'),
        );
    }

    public function pivotModels() {
        return array(
        );
    }

    public function attributeLabels() {
        return array(
            'factsheetid' => Yii::t('app', 'Factsheetid'),
            'name' => Yii::t('app', 'Name'),
            'toolid' => null,
            'weight' => Yii::t('app', 'Weight'),
            'inputdate' => Yii::t('app', 'Inputdate'),
            'tool' => null,
            'factsheetcontents' => null,
            'factsheetimages' => null,
        );
    }

    public function search() {
        $criteria = new CDbCriteria;

        $criteria->compare('factsheetid', $this->factsheetid);
        $criteria->compare('name', $this->name, true);
        $criteria->compare('toolid', $this->toolid);
        $criteria->compare('weight', $this->weight);
        $criteria->compare('inputdate', $this->inputdate, true);

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

知道如何解决我的问题吗?我已经给了我所有的系统内存(memory_init(-1)),只是得到了堆转储错误。我需要帮助,请告诉我在哪里看,因为我对Yii完全是新手。

1 个答案:

答案 0 :(得分:0)

您通常会将此错误作为_form部分文件的一部分。当GxHtml生成一个下拉菜单时,我经常遇到它。

GiiX在将所有模型从数据库中正确拉出并为您的下拉列表获取适当的键/名称方面效率不高。因此,通常最好指定要手动检索的字段。

如果您发布_form代码(或至少相关部分),我们可以指出该行。