Выборка с использованием условия ИЛИ для системного поля — различия между версиями
Williwaw (обсуждение | вклад) (Новая страница: «'''Актуально для версии 2.9.6''' == Задача == Предположим необходимо отобрать страницы(наприме…») |
Williwaw (обсуждение | вклад) |
||
Строка 17: | Строка 17: | ||
== Решение == | == Решение == | ||
− | Реализовать такую выборку в UMI.CMS можно сделав два запроса к базе и получить "пересечение" их результатов, т.е. id | + | Реализовать такую выборку в UMI.CMS можно, сделав два запроса к базе и получить "пересечение" их результатов, т.е. id страниц, а затем отобрать в результирующем запросе страницы с данными id |
+ | Предположим, будем искать страницы, у которых либо идентификатор находится в определенном диапазоне, либо страница отмечена чекбоксом, который создал пользователь. На самом деле, режим or-mode в данном случае не понадобится: | ||
<source lang="php"> | <source lang="php"> | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
</source> | </source> |
Версия 09:52, 2 июня 2014
Актуально для версии 2.9.6
Задача
Предположим необходимо отобрать страницы(например товары) у которых либо id входит в множество определенных значений, либо у этой страницы любое другое поле равно определенному значению. Для выборки с условием "ИЛИ" используется or-mode, но дело в том, что для системных полей данный режим не сработает. Системные поля - это:
- 'id'
- 'name'
- 'owner'
- 'domain'
- 'lang'
- 'is_deleted'
- 'is_active'
- 'is_visible'
- 'updatetime'
- 'is_default'
- 'template_id'
Решение
Реализовать такую выборку в UMI.CMS можно, сделав два запроса к базе и получить "пересечение" их результатов, т.е. id страниц, а затем отобрать в результирующем запросе страницы с данными id Предположим, будем искать страницы, у которых либо идентификатор находится в определенном диапазоне, либо страница отмечена чекбоксом, который создал пользователь. На самом деле, режим or-mode в данном случае не понадобится: