Yii2 - игнорирование условия «ИЛИ», когда Null

У меня есть этот запрос, который работает нормально

$order_items= OrderItem::find()
->where(['location_id'=>$model->location_name,'instructor_id'=>$model->instructor_name])
->andwhere(['between', 'date', $model->from_date, $model->to_date ])->all();

Но когда $model->instructor_name пустое или нулевое, я получаю нулевой результат. Поэтому я хочу игнорировать, когда instructor_id имеет значение Null когда

'instructor_id'=>$model->instructor_name or instructor_id'=> Null

как я могу это сделать?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
61
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

$order_items= OrderItem::find()
->where(['location_id'=>$model->location_name,'instructor_id'=>$model->instructor_name])
->andWhere(['not', ['instructor_id' => null]])
->andwhere(['between', 'date', $model->from_date, $model->to_date ])->all();

Или добавьте следующее

  ->andWhere(['<>', 'instructor_id', null])

Или

 ->andWhere('instructor_id IS NOT NULL')
Ответ принят как подходящий

Вы должны использовать иФильтрГде()

$order_items = OrderItem::find()
   ->where(['location_id' => $model->location_name])
   ->andFilterWhere(['instructor_id' => $model->instructor_name])
   ->andwhere(['between', 'date', $model->from_date, $model->to_date ])
   ->all();

Другие вопросы по теме