Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
13.03.2018, 22:54
|
|||
---|---|---|---|
|
|||
Представление множеств |
|||
#18+
Нужно сделать параметрический поиск для деталей с 10-20 параметрами, как это сделано во многих магазинах, например яндекс маркете. Сложность в выводе возможных значений параметров при уже примененных фильтрах. Например, есть таблица с параметрами конденсаторов - part_number, manufacturer, voltage, capacitance, case и т.д. Для каждой колонки уникальных значений не очень много, от 5 до 400. Должны отображаться списки производителей, напряжения, емкости и т.д. При выборе одного или нескольких параметров из какого-либо списка, остальные списки должны усекаться в соответствии с выбранными ограничениями. Я пытался получать эти списки как-то так (повторял для каждого интересующего столбца): Код: sql 1.
Проблема в том, что для таблицы с полумиллионом строк два десятка таких запросов выполняются слишком медленно. Наверное нужно каждому значению каждого параметра сопоставлять множества других параметров, и считать уже пересечения этих множеств. Но как это сделать? Не бейте меня, я вообще не программист. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
14.03.2018, 22:46
|
|||
---|---|---|---|
Представление множеств |
|||
#18+
Читать тут: https://en.wikipedia.org/wiki/Entity–attribute–value_model Или ищи по форуму "Проектрование БД" по слову EAV ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/topic.php?fid=54&mobile=1&tid=2008460]: |
0ms |
get settings: |
8ms |
get forum list: |
12ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
160ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
41ms |
get tp. blocked users: |
1ms |
others: | 238ms |
total: | 478ms |
0 / 0 |