Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Формирование sql запроса из набора фильтров
Форумы портала PHP.SU » PHP » Напишите за меня, пожалуйста » Формирование sql запроса из набора фильтров

Страниц (1): [1]
 

1. Jlblcblu - 07 Декабря, 2012 - 11:59:43 - перейти к сообщению
В довольно-таки популярном js-фреймворке kendo присутствует виджет grid. Из названия виджета понятно, что он представляет из себя таблицу. При проведении фильтрации, сортировки и т.п., грид отправляет набор фильтров, из которых потом формируется sql-запрос.

Вот пример отправляемых данных:
CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2. filter[logic]:and
  3. filter[filters][0][logic]:or
  4. filter[filters][0][filters][0][field]:id_ad
  5. filter[filters][0][filters][0][operator]:contains
  6. filter[filters][0][filters][0][value]:
  7. filter[filters][0][filters][1][field]:id_user
  8. filter[filters][0][filters][1][operator]:contains
  9. filter[filters][0][filters][1][value]:
  10. filter[filters][1][field]:status_db
  11. filter[filters][1][operator]:eq
  12. filter[filters][1][value]:active
  13. filter[filters][2][field]:status_nodb
  14. filter[filters][2][operator]:eq
  15. filter[filters][2][value]:active
  16.  


Фильтры соединены между собой логикой [logic] : or/and. Если [value] фильтра приходит пустым - фильтр необходимо игнорировать.

Операторы eq и contains обозначают = 'value' и like '%value%' соответственно.

Из примера выше видно, что фильтры могут быть вложены. Таким образом тут необходима рекурсия.

Вот запрос. который должен получиться исходя из текущих фильтров.
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. SELECT * FROM mytable WHERE status_db='active' AND status_nodb = 'active' AND (id_ad LIKE '%1%' OR id_user LIKE '%1%')
  3.  


Была написана костыльная версия фильтрации, она под спойлером.
Спойлер (Отобразить)


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

 

Powered by ExBB FM 1.0 RC1