lbondodesc
@lbondodesc
PHP Developer

Yii2 Как выполнить запрос с подзапросом с помощью Active Records?

Как выполнить такой запрос с помощю моделей Active Record?
SELECT rooms.id_room, rooms.number
    FROM rooms
    LEFT JOIN reservation ON rooms.id_room = reservation.id_room
    WHERE rooms.id_room NOT IN (
    		SELECT reservation.id_room
    		FROM reservation
    		WHERE CURDATE() BETWEEN reservation.lock_start AND reservation.lock_finish
    )

Делаю так но появляется ошыбка Undefined variable: rdRooms
public function getReservation()
    {
    	return $this->hasMany(Reservation::className(), ['id_room' => 'id_room']);
    }
............................................................................................................................
$rdRooms = (new Query)->select('reservation.id_room')
    				->from('reservation')
    				->where(':now BETWEEN reservation.lock_start AND reservation.lock_finish')
		        	->addParams([':now' => date('Y-m-d')]);
    	
$rooms = Rooms::find()->joinWith([
		    'reservation' => function ($query) {
		        $query->where(['rooms.id_room' => $rdRooms]);
		    }
  • Вопрос задан
  • 5127 просмотров
Решения вопроса 1
@bighoc
php/javascript developer
что бы переменную было видно нужно передать её в анноимную функцию, кажется вот так:
$rooms = Rooms::find()->joinWith([
        'reservation' => function ($query) use ($rdRooms){
            $query->where(['rooms.id_room' => $rdRooms]);
        }
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы