Вывод данных в GridView из двух таблиц

Темы, не касающиеся фреймворка, но относящиеся к программированию в целом.
Ответить
ivan_freestyle
Сообщения: 7
Зарегистрирован: 2018.04.23, 11:24

Вывод данных в GridView из двух таблиц

Сообщение ivan_freestyle »

Всем привет!

Есть две таблицы:
oblasti (oblast_id, oblast_name)
goroda (goroda_id, oblast_id, gorod_name)

Где oblast_id является связующим столбцом.

Используя генератор кода Gii я сгенерил:
Model - 2 шт
и CRUD - 2 шт

Для связки таблиц я использовал hasOne;
Чтобы получить данные из второй таблицы использовал leftJoin;

Код: Выделить всё


public function getOblasti()
{
	return $this->hasOne(Oblasti::className(), ['oblast_id' => 'oblast_id']);
}
	
	
 public function search($params)
 {
		
	$query = Goroda::find();
	
	$dataProvider = new ActiveDataProvider([
            'query' => $query->oblasti,
        ]);
	
        $this->load($params);

        if (!$this->validate()) {
            // uncomment the following line if you do not want to return any records when validation fails
            // $query->where('0=1');
            return $dataProvider;
        }

        // grid filtering conditions
        $query->andFilterWhere([
            'gorod_id' => $this->gorod_id,
            'oblast_id' => $this->oblast_id,
        ]);

		
		
        $query->andFilterWhere(['like', 'gorod_name', $this->gorod_name])->leftJoin('oblasti', 'oblasti.oblast_id = goroda.oblast_id');
		

        return $dataProvider;
}


При выводе данных использовал 'oblasti.oblast_name', но выдает ошибку - "Getting unknown property: yii\db\ActiveQuery::oblasti"

Код: Выделить всё

    GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],

            'gorod_id',
            'oblasti.oblast_name'
            'gorod_name',

            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]);

Большая просьба, как исправить ситуацию?
ivan_freestyle
Сообщения: 7
Зарегистрирован: 2018.04.23, 11:24

Re: Вывод данных в GridView из двух таблиц

Сообщение ivan_freestyle »

ElisDN писал(а): 2019.01.08, 09:56 'query' => $query,
Здравствуйте! Большая просьба, подскажите, как правильно связать модели? Т.е. куда вставить getOblasti?
И подскажите я правильно сделал leftJoin?

Код: Выделить всё

$query->andFilterWhere(['like', 'gorod_name', $this->gorod_name])->leftJoin('oblasti', 'oblasti.oblast_id = goroda.oblast_id');
vikeng
Сообщения: 2
Зарегистрирован: 2014.11.07, 15:31

Re: Вывод данных в GridView из двух таблиц

Сообщение vikeng »

getOblasti() нужно вставить в модель с городом.
Т.е. связь getOblasti должен быть в файле Goroda.php, функция search в GorodaSearch.php

leftJoin кажется написан правильно, но т.к. связь есть лучше вместо него использовать joinWith('oblasti'). Это проще, меньше возможности ошибиться.
ivan_freestyle
Сообщения: 7
Зарегистрирован: 2018.04.23, 11:24

Re: Вывод данных в GridView из двух таблиц

Сообщение ivan_freestyle »

Здравствуйте! Спасибо за помощь.
Ответить