|
3 / 3 / 0
Регистрация: 03.10.2012
Сообщений: 50
|
|
MySQL Select + JOIN или несколько select04.08.2016, 11:26. Показов 1376. Ответов 2
Сейчас занимаюсь проектированием архитектуры своего (будущего) php-приложения и наткнулся на противоречие. (по крайней мере для меня оно таково)
Простой пример (структура приложения построена на основе MVC, есть ядро с некоторым набором функционала и есть модули): Страница и комментарии: В данном случае Вывод страницы и ее данных - состоит в core Комментарии - модуль, который будет подгружаться и выводиться на нужной позиции views. Так вот, если не следовать такому разделению, комменты- модуль, старница - часть ядра, то мы получаем данные страницы, а джоином(точнее несколько) подхватываем все комментарии, относящиеся к ней и выводим Если же соблюдаем структуру (т.е. подгружаем комменты или что-то еще отдельным модулем, что очень удобно для динамического подключения модулей и не вызывает необходимости править важные компоненты при добавлении новых модулей), то комменты и данные других модулей у нас будут порождать новые селекты. Так вот в чем противоречие с модулями удобно, без них должно быть быстрее, есть ли возможность как-то это совместить, может паттерн какой, или технология?
0
|
|
| 04.08.2016, 11:26 | |
|
Ответы с готовыми решениями:
2
Select inner join (форматирование вывода) Изменение данных одного select при изменении другого select Как сделать чтобы при выборе одного варианта из select другие select скрывались |
|
36 / 36 / 18
Регистрация: 01.01.2015
Сообщений: 287
|
||||||
| 05.08.2016, 23:46 | ||||||
|
а комменты случайно не подобным образом берутся:
помимо текста комментария содержит еще и данные_страницы(которые скорее всего >> комментариев) ? в любом случае мне видится два варианта решения: -не использовать JOIN, модули на вход получают id страницы -использовать конструктор запросов, выглядеть это может так: https://symfony.com/doc/curren... ry-builder модули в свою очередь могут подписываться на эвенты(события) ядра, например, при получении статьи ядро генерирует событие, параметром которого является конструктор запроса, когда модуль получает это событие, он добавляет свой join в конструктор, а затем в следующем событии вытаскивает свои данные из результата.
0
|
||||||
|
146 / 105 / 44
Регистрация: 30.04.2016
Сообщений: 550
|
|
| 06.08.2016, 13:55 | |
|
Разделяйте комментарии и посты. Комментарии получайте отдельно, никаких JOINов тут не нужно, да и не правильно это.
0
|
|
| 06.08.2016, 13:55 | |
|
Помогаю со студенческими работами здесь
3
Выборка из БД и вставка данных в <select></select> Сохранение значения select и работоспособность второго select после отправки формы При выборе элемента в <select> менять содержимое другого <select> Как при выборе значения в select выполнить функцию php и передать в ей аргумент (значение select) Несколько select option Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
|
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|