Аргумент 2, передаваемый в yii \ db \ condition \ HashConditionBuilder :: build (), должен иметь тип массива, строка указана в Yii2 - PullRequest
0 голосов
/ 25 апреля 2020

когда я пытаюсь соединить две таблицы, я получаю ошибку.

вот мой контроллер

public function actionView($id)
{
    $view = (new \yii\db\Query())
        ->select(['id', 'user_id', 'body', 'title'])
        ->join('INNER JOIN', 'users', 'blog.user_id','users.id')
        ->where(['blog.id' => $id])
        ->one();

    return $this->render('view', compact('view'));
}

вот мой взгляд

 <div class="col-lg-4">
            <h2><?= $view['name'] . ' ' . $view['surname'] ?></h2>
            <h3><?= $view['title']; ?></h3>
            <p><?= $view['body']; ?></p>
            <a href="<?php echo yii::$app->homeUrl; ?>" class="btn btn-default">Back </a>
            <?= Html::a('Delete', ['delete', 'id' => $view['id']], ['class' => 'btn btn-danger']) ?>
        </div>

1 Ответ

1 голос
/ 25 апреля 2020

Что касается prima vista, очевидно, что вы забыли предложение from в QueryBuilder.

. Взгляните на это:

$view = (new \yii\db\Query())
        ->select(['id', 'user_id', 'body', 'title'])
        ->from('blog') // this is your from clause of the query
        ->join('INNER JOIN', 'users', 'blog.user_id = users.id')
        ->where(['blog.id' => $id])
        ->one();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...