Ошибка при попытке вставить данные в несколько таблиц в Yii2 - PullRequest
0 голосов
/ 22 января 2019

Когда я пытаюсь отобразить данные из связанной таблицы, я получаю сообщение об ошибке Call to a member function isAttributeRequired() on null.

У меня есть таблицы: PromoCode, SubscribePrice и PromoToSubscribePrice. Но когда я пытаюсь отобразить таблицу Sub в промо-коде, я получаю сообщение об ошибке.

Мне нужна следующая ссылка: При создании таблицы PromoCode мы могли бы сделать выборку данных (select2) из ​​таблицы SubscribePrice, и то, что мы там выбрали, было сохранено только в таблице SubscribeToPromoCode.

В настоящее время, когда я пытаюсь передать атрибут, я получаю NULL

У меня много-много соединений во всех таблицах

Модель: PromoCode

public function getPromoToSubscribePrice()
{
    return $this->hasMany(SubscribePrice::class, ['id' => 'id'])
    ->viaTable('promo_to_subscribe_price', ['promo_id' => 'id']);
}

Контроллер: PromoCodeController

public function actionCreate()
{
    $model = new PromoCode();
    $price = SubscribePrice::find();
    $PromoToSubscribePrice = new PromoToSubscribePrice();

    $PromoToSubscribePrice->promo_id = $model->id;
    $PromoToSubscribePrice->price_id = $model->article_id;
    $PromoToSubscribePrice->setAttributes(Yii::$app->request->post());
    if ($model->load(Yii::$app->request->post()) && $model->save()) {
        return $this->redirect(['view', 'id' => $model->id]);
    } else {
        return $this->render('create', [
            'model' => $model,
            'promo' => $price,
        ]);
    }
}

и view:

<?= $form->field($promo, 'description')->widget(Select2::className(), [
    'data' => SubscribePrice::find()->orderBy('currency'),
    'options' => [
        'placeholder' => 'Select contributors ...',
        'multiple' => true
    ],
    'pluginOptions' => [
        'allowClear' => true
    ],
]); ?>

Результат: Ошибка: вызов функции-члена isAttributeRequired () для null.

Что я делаю не так?

Вход:

Error: Call to a member function isAttributeRequired() on null in C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\widgets\ActiveField.php:859
Stack trace:
#0 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\widgets\ActiveField.php(720): yii\widgets\ActiveField->addAriaAttributes(Array)
#1 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\backend\views\promo-code\_form.php(36): yii\widgets\ActiveField->widget('kartik\\widgets\\...', Array)
 #2 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\View.php(328): require('C:\\program1\\Ope...')
#3 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\View.php(250): yii\base\View->renderPhpFile('C:\\program1\\Ope...', Array)
#4 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\View.php(152): yii\base\View->renderFile('C:\\program1\\Ope...', Array, NULL)
#5 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\backend\views\promo-code\create.php(18): yii\base\View->render('_form', Array)
#6 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\View.php(328): require('C:\\program1\\Ope...')
#7 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\View.php(250): yii\base\View->renderPhpFile('C:\\program1\\Ope...', Array)
#8 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\View.php(152): yii\base\View->renderFile('C:\\program1\\Ope...', Array, Object(backend\controllers\PromoCodeController))
#9 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\Controller.php(381): yii\base\View->render('create', Array, Object(backend\controllers\PromoCodeController))
#10 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\backend\controllers\PromoCodeController.php(82): yii\base\Controller->render('create', Array)
#11 [internal function]: backend\controllers\PromoCodeController->actionCreate()
#12 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\InlineAction.php(57): call_user_func_array(Array, Array)
#13 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\Controller.php(156): yii\base\InlineAction->runWithParams(Array)
#14 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\Module.php(523): yii\base\Controller->runAction('create', Array)
#15 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\web\Application.php(102): yii\base\Module->runAction('promo-code/crea...', Array)
#16 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\vendor\yiisoft\yii2\base\Application.php(380): yii\web\Application->handleRequest(Object(yii\web\Request))
#17 C:\program1\OpenServer\OSPanel\domains\masterRoom\master\backend\web\index.php(19): yii\base\Application->run()
#18 {main}

1 Ответ

0 голосов
/ 22 января 2019

Обновление

Помимо проблемы, выявленной ранее, у вас есть та же ошибка в опции data Select2

'data' => SubscribePrice::find()->orderBy('currency'),

, которую вы передаететам тоже экземпляр ActiveRecord, тогда как вам нужно передать массив с парами name=>value, это должно быть

'data' => \yii\helpers\ArrayHelper::map(SubscribePrice::find()->orderBy('currency')->all(),'id','currency')

Использовать ArrayHelper :: map () для извлечения столбцов как ассоциативныхмассив и перечисление их внутри select2.


Ваша проблема здесь во второй строке actionCreate()

$price = SubscribePrice::find();

, поскольку $price содержит экземпляр ActiveRecord, а неэкземпляр model и $price передаются в представление как promo в этой строке

return $this->render('create', 
    [
        'model' => $model,
        'promo' => $price,
    ]
);

, которое далее используется в заполнении поля ActiveForm <?= $form->field($promo, 'description')->widget(Select2::className(), [, тогда как при заполнении поля выВам нужен экземпляр модели, а не ActiveQuery, поэтому измените его на.

$price = new SubscribePrice();

или

$price = SubscribePrice::find()->where(['column'=>$value])->limit(1)->one();

, в зависимости от того, что соответствует вашим требованиям.

...