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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Формирование sql запроса из набора фильтров

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
Jlblcblu
Отправлено: 07 Декабря, 2012 - 11:59:43
Post Id



Новичок


Покинул форум
Сообщений всего: 36
Дата рег-ции: Март 2010  


Помог: 1 раз(а)




В довольно-таки популярном 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.  


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


Помогите, пожалуйста, написать нормальную функцию, которая могла бы обрабатывать присылаемые фильтры. Я думаю это будет полезно многим, кто использует подобную фильтрацию.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB