所以我继承了一个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完全是新手。
答案 0 :(得分:0)
您通常会将此错误作为_form部分文件的一部分。当GxHtml生成一个下拉菜单时,我经常遇到它。
GiiX在将所有模型从数据库中正确拉出并为您的下拉列表获取适当的键/名称方面效率不高。因此,通常最好指定要手动检索的字段。
如果您发布_form代码(或至少相关部分),我们可以指出该行。