Jump to main content Jump to doc navigation

xPDOQuery::orCondition

Добавьте условие OR в операторWHERE в запросе.

Синтаксис

API Docs: xPDOQuery::orCondition()

void orCondition ( $conditions, [ $binding = null], [ $group = 0])

Пример

Возьмите все коробки шириной 12 или 14.

$query = $xpdo->newQuery('Box');
$query->where(array(
   'width' => 14,
));
$query->orCondition(array(
   'width' => 12,
));
$boxes = $xpdo->getCollection('Box',$query);

Предупреждение

Порядок вызова функций важен! orCondition должно следовать после where, где метод был использован.

Другой пример

Вот более знакомый пример, используемый для получения страниц, когда у них установлены даты publish/unpublish. Это демонстрирует альтернативный синтаксис для условия или. Обычно каждое место в массиве, предоставленном методу where, где объединяется с помощью SQL AND, но вы можете использовать префикс OR в именах столбцов, чтобы указать, как группы терминов объединяются.

В следующем примере страница must должна быть опубликована (1), а pub_date должен быть либо нулевым, либо меньшим или равным текущей отметке времени. Значение unpub_date должно быть либо нулевым, либо большим, чем текущая временная метка.

$criteria = $modx->newQuery('modResource');
$criteria->where(array(
    'published' => 1,
        array(
            'pub_date' => 0,
            'OR:pub_date:<=' => time(),
        ),
        array(
            'unpub_date' => 0,
            'OR:unpub_date:>' => time(),
        ),
    )
);

Пример c объединенными столами

Параметры вашего фильтра могут ссылаться на поля в других таблицах.

$query = $modx->newQuery('modUser');
$query->innerJoin('modUserProfile','Profile');
$query->where(array(
   'modUser.username' => $email,
));
$query->orCondition(array(
   'Profile.email' => $email,
));
$user = $modx->getObject('modUser', $query);

Параметры фильтра могут использовать имя класса (как в modUser выше) или псевдоним (как профиль выше).

Смотрите также

Support the team building MODX with a monthly donation.

The budget raised through OpenCollective is transparent, including payouts, and any contributor can apply to be paid for their work on MODX.

Backers

  • modmore
  • STERC
  • Digital Penguin
  • Jens Wittmann – Gestaltung & Entwicklung
  • Fabian Christen
  • Dannevang Digital
  • Sepia River Studios
  • CrewMark
  • Chris Fickling
  • deJaya
  • Lefthandmedia
  • Murray Wood
  • eydolan
  • Following Sea
  • Anton Tarasov
  • Stéphane Jäggi
  • Raffy
  • Snow Creative
  • A. Moreno
  • Nick Clark
  • JT Skaggs
  • Helen
  • YJ
  • krisznet
  • Richard
  • Yanni

Budget

$301 per month—let's make that $500!

Learn more