[MODX, MiniShop2] Примеры выборки where, optionFilters, innerJoin

WHERE в proResouces, msProducts
Примеры использования в pdoTools

  • &where=`{"parent=":75}`
    &where=`{"parent":75}` — Выбрать ресурсы по паренту. Эквивалентно &parents=`75` (если не указан никакой знак, то по умолчанию это =)
  • &where=`{"template:IN":[1,2,3]}` — Выборка по массиву значений. (Только ресурсы некоторых шаблонов)
  • &where=`{"parent:NOT IN":[75,147,80]}` — Выборка за исключением массива значений. (Ресурсы, кроме тех, у которых родителем является 75,147,80)
  • &where=`{"Data.old_price:>":0}` — Условие "больше чем". (Товары, у которых указана старая цена)
  • &where=`{"Data.old_price:<=":1000}` — Условие "меньше или равно"
  • &where=`{"uri:LIKE":"%games%"}` — Условие WHERE LIKE (содержит подстроку "games")
  • &where=`{"uri:NOT LIKE":"games%"}` — Условие WHERE NOT LIKE (подстрока не начинается на "games")
  • &where=`{"uri:LIKE":"%games"}` — Условие WHERE LIKE (содержит подстроку "games", которая находится в конце строки)
  • Условия AND, OR
  • &where=`{"article:LIKE":"PGS_%","Data.price:<":500}` — Условие AND (article начинается на "PGS_" и цена больше 500)
  • &where=`{"parent":4,"OR:template":5}` — Условие OR

&optionFilters, NOT IN
Выборка товаров по опциям

Входные данные:

  • Опции товара exist (тип «Выпадающий список»), в которой указывается статус наличия/доставки

Задача

  • Сделать выборку по тем товарам, у которых НЕ указаны статусы "Нет в наличии" и "Только самовывоз"
[[!msProducts?
  &parents=`0`
  &depth=`10`
  &limit=`0`
  &tpl=`yml_offer`
  &optionFilters=`{"exist:NOT IN":[ "Нет в наличии", "Только самовывоз" ]}`
]]

&innerJoin, msProductOption
Выбрать товары по диапазону дат, указанных в опциях

Входные данные:

  • Опции товара yml_promo_start и yml_promo_end, формата Дата (2018-10-24)

Задача

  • Выбрать товары, у которых указанная дата начала акции yml_promo_start больше или равна текущей даты, а yml_promo_end меньше или равна текущей дате.

Как это сделать через &optionFilters я не понял (пожалуйста, напишите в комментариях если вы знаете решение). Но через &innerJoin вполне:

(Соответствие названия классов с названиями таблиц в MySQL)

[[!msProducts?
  &parents=`0`
  &depth=`10`
  &limit=`0`
  &tpl=`yml_promo`
  &innerJoin=`{
  "option1": {
    "class": "msProductOption",
    "on": "option1.key = 'yml_promo_end' AND option1.product_id = msProduct.id AND option1.value != 0 AND option1.value >= now()"
  },
  "option2": {
    "class": "msProductOption",
    "on": "option2.key = 'yml_promo_start' AND option2.product_id = msProduct.id AND option2.value != 0 AND option2.value <= now()"
  }
}`
]]

&tvFilters
Выборка по доп. полям (TV-полям)

Теория (примеры ниже)

Соответсвие операторов, используемых в &tvFilters с операторами SQL. Найдены внутри метода addTVFilters в файле core/components/pdotools/model/pdotools/pdofetch.class.php

Кому-то эта информация покажется избыточной, но я думаю, что это следует знать, чтобы четко понимать во что преобразается написанный вами запрос, и соответсвенно лучше контролировать результат.

Слева указан вид, который пишем при вызове сниппета, справа — то, что получается при формировании запроса. В примерах преобразования показано как это происходит. (Вы легко сможете повторить эти эксперементы, запустив сниппет с параметром &showLog=`1`)

  • <=> => <=>
  • === => =

    Примеры преобразования:
    &tvFilters=`mytvname===Lorem ipsum dolor sit amet`
    `TVmytvname`.`value` = 'Lorem ipsum dolor sit amet'

  • !== => !=
  • <> => <>
  • == => LIKE

    Примеры преобразования:
    &tvFilters=`mytvname==Lorem ipsum dolor sit amet`
    `TVmytvname`.`value` LIKE 'Lorem ipsum dolor sit amet'

    Еще один пример:
    &tvFilters=`mytvname==%Lorem%`
    `TVmytvname`.`value` LIKE '%Lorem%'

  • != => NOT LIKE

    Примеры преобразования:
    &tvFilters=`mytvname!=%Lorem%`
    `TVmytvname`.`value` NOT LIKE '%Lorem%'

  • << => <
  • <= => <=
  • =< => =<
  • >> => >
  • >= => >=
  • => => =>

Примеры использования &tvFilters

Вывести только ресурсы, у которых ТВ important-page (тип «чекбокс») отмечен

  • &tvFilters=`important-page==1`
Способ поблагодарить автора сайта:

Комментарии (0)

  1. Напишите первый комментарий
*Комментарий будет опубликован после проверки модератором

[MODx] Подсказки по API

[MODx] minishop2 tips

[Code helper] Заготовки для работы

[MODX] Если getParentIds не работает в плагине

[MODX, miniShop2] Сделать поле размер обязательным

[MODX, MiniShop2] Примеры выборки where, optionFilters, innerJoin

Отключить автозаполнение input

Преобразовать кодировку в utf8 для базы MySQL

Преобразовать JSON в HTML

[MODX] Загрузка сниппета после загрузки страницы через AjaxSnippet

[MODX, MiniShop2] Отредактировать письмо о заказе - добавить ТВ поле, или что-то еще

[MODX, pdoCrumbs] Вывести список всех родителей в ТВ поле ресурса

[JS] Связать значения инпутов через jQuery (биндинг)

[MODX] Массово обновить ТВ, или другое поле через базу

[miniShop2] Разместить корзину внутри блока с оформлением заказа

[OpenCart 1.5.1] Массово изменить адреса картинок у товаров

Вывести список всех файлов на сервере (и размер файла)

[PHP] Фиксированная сортировка массива на основе хэша

Курсы валют с cbr.ru на PHP, с запасным вариантом и кэшированием

[MODX] pThumb - ресайз изображений. Примеры использования.

Изменить цену на товар, если в корзине лежит товар из особой категории minishop2

Скрыть информацию о том, что сайт работает на MODX

[MODX] Сообщение о том, что сайт использует Cookie

Не работает подгрузка товаров ajax mfilter2 на мобильном

Постраничная навигация — набор параметров и CSS PdoPage

Разбить вывод pdoResources на несколько колонок (блоков)

[MODX] Добавить скрипт перед тегом body

[PHP] Узнать скорость выполнения кода. Простой таймер PHP

Вывести список всех емэйлов miniShop2

[MODX] Создать редирект через autoRedirector API

[MODX, MiniShop2] Отредактировать шаблон письма

[MODX] Кастомный чанк для AdminPanel

[MODX] Оформление и настройка easyComm. Комментарии и отзывы на сайте.

[MODX, MiniShop2] Обязательный чекбокс при оформлении заказа

[JS] Маска для ввода телефона +7(___)___-__-__

[MODX, MiniShop2] Добавить в письмо контактную информацию

[MODX, MiniShop2] Email сделать не обязательным полем

[MODX] Импорт и экспорт в MiniShop2. Реализация 1

[MODX, MiniShop2] Изменить формат номера заказа

Изменить цену на товар в зависимости от количества при добавлении в корзину minishop2

Общая сумма по каждому товару в корзине Minishop2

reCaptcha не через форму (без тега <form>)

Расширение свойств товаров minishop2

pdoPage и getImageList - Постраничная навигация MIGX

[MODX] Соответствие названия классов с названиями таблиц в MySQL

Вывести 404 ошибку по настройки TV MODX

Расширить таблицу site_content (объект modResource) за 5 минут

Передать файл с одного на другой сервер

Создать ресурс процессором $modx->runProcessor('resource/create', $props)

Как включить HTTPS (SSL) в MODX - Подробная инструкция

[MODX, MIGX] Простейшая авторизация

[MIGX] Простая и симпатичная галерея fancybox

[MODX] Узнать размер файла

Красивое адаптивное меню под pdoMenu

pdoResources Заготовки для работы

FontAwesome - часто используемые иконки для шаблонов MODX

[MODX, MIGX] Тип поля "Список ресурсов" (resourcelist) с ограничением по родителю (parents)

[MODX, MIGX] Вывести getImageList только если он не пустой

Bxslider отображение картинок после полной загрузки слайдера

[MODX] Вывести список всех опций MiniShop2

[MODX] Курсы валют с cbr.ru на PHP

[MODX, MIGX] Простой аудио-плеер HTML5

Как контролировать кэш CSS и скриптов

[OpenCart] Вывести на главную все категории с картинками

[PHP] Получить древовидный массив за один запрос к базе

Вырезать кавычки - фильтр MODx

Регулярное выражение

[MODx] Генератор настроек MIGX

[MODx, MIGx] Документация на русском по MIGx

[MODx] Динамическое поле emailSubject в FormIt

[MODx] Установить шаблон по-умолчанию для новых, создаваемых ресурсов

[MODx,MiniShop2] Не приходит почта администратору

[MODx] Баннеры с использованием BannerY

[Opencart] Вернуть английский язык, если вы его удалили

Универсальная форма обратной связи — feedBackForm

[MODx, miniShop2] Генерация YML для выгрузки в маркет

Редиректы

[MODx] pdoPage pagination css

[MODx] Вывести время загрузки (формирования) страницы

[MODx] Создать источник файлов

[MODx, minishop] Фильтрация по TV параметрам в msProducts

Регулярные выражения notepad++ примеры

[MODx] Создать свою страницу в админке

[JS] Заготовочки

[MODx] Поиск на сайте с пакетом SimpleSearch

[MODx, XML] Ответ для сервиса moneta.ru

[MODx] Подключить MODx в стороннем PHP файле

[MODx] Создать пакет с пользовательской таблицей

[PHP] Простое логирование

[OpenCart] Вывести модуль напрямую через контроллер

[MODx, Gallery] Галерея. Вывести обложки альбомов и фотографии

[MODx, MIGX] Примеры использования

[MODx] Сайт на обслуживании (выключить сайт)

[Opencart, FilterPro] Не работает пагинация

[OpenCart] Заготовки для автоматического заполнения товарами магазина 1.5.5.1.2

[PHP] Разные фишки, заготовки

[PHP, JSON] Пример перевода с помощью Yandex Translate API

[MySQL] Примеры запросов

[MODx] Вывод tv-параметров в формате [название TV] - [значение TV]

[MODx] Дата на русском

[MODx] Ускорить установку MODx revo до пары кликов

[Opencart] API tips

[MODx, Quip] Отсортировать ресурсы по количеству комментариев Quip MODx

[PHP] Загрузить файл для постобработки

[Opencart 2] Показывать в категориях

[MODx, Quip] Более рабочий вариант.

[MODx] Получить grandparent. Вывести родитель родителя

[MODx] Вывести все доступные плейсхолдеры.

[MODx] getResources заготовки

[MODx] Счетчик посещений и скачиваний для сортировки ресурсов

[MODx] Как разместить исходный код сниппета на сайте, в документации

Удалить HTML-теги span, и стили из тега br

Полезные ссылки

Все записи