в другой таблице (таблица с авторами фотографий). Я получаю её использую eloquent relations и меня в общем-то всё устраивает.
Но появилось желание сортировать фотографии не только по их характеристикам из их таблицы, но и по характеристикам авторов фотографии. Как лучше всего это реализовать? Можно заменить eloquent relations на запрос с join'ами, но тогда я потеряю преимущества отношений. Можно сортировать на стороне клиента, но это не очень эффективно с точки зрения скорости и производительности. Как быть? Может, есть какой-то другой вариант?
это разные инструменты. тут просто добавить как раз джоины или подзапросы с сортировкой
sortBy('photo.item')
sortBy это ж метод для работы с коллекциями. Таким образом, если в таблице много записей, это решение будет работать медленно.
Да и вообще, сортировка не на стороне mysql получается.
джойн будет быстрее, но с полиморфными связями не прокатит
Джоины => теряю гибкость отношгений. Подзапросы с сортировкой сейчас полуркаю.
Вот тут товарищ говорит про какие-то подзапросы, кажется, хорошее решение.
отношения не трогай. эт отдельные запросы и они побыстрее джойнов и т.д. другое дело если нужны доп данные из других таблиц, то только джойны и подзапросы. не нужно из этих данных делать модели отношений, там вообще все сломается
технически они не быстрее джойнов тут дело в гибкости
обсуждалось много раз.. от движка конечно зависит, но читать две большие табилцы сложнее, чем по id вытащить N на страницу
1. Нужен 1 раунд робин по сети чтобы передать все эти айди 2. Внутри пыхи мерж данных немного медленнее будет тк это пыха и не используются индексы
Обсуждают сегодня