170 похожих чатов

Привет! Делаю такой запрос $contacts = Message::where(['from' => $user->id])->orWhere(['to' => $user->id])->get(); Выводится две

записи, как сделать так чтобы если to или from повторяется, то выводим одну запись (при этом они могут не повторятся) ?

7 ответов

5 просмотров

а че не делаеш group by ?

.- Автор вопроса

Он же сортирует записи, причем тут это?)

делай group by from, и будет тебе счасте

Можешь заджоинить таблицу на себя t1.from = t2.from and t1.to = t2.to сгрупировать и достать агрегированной функцией в селекте что тебе надо Можно без джоина, но надо проверить производительность, что-то вроде этого: Message::selectRaw(MAX('id'))->groupByRaw(CASE WHEN messages.to > messages.from THEN CONCAT_WS('', messages.to, messages.from) ELSE CONCAT_WS('', messages.from, messages.to) END)

вопшета сортировку делает order by

.- Автор вопроса

SQLSTATE[42000]: Syntax error or access violation: 1055 'botprokat.messages.id' isn't in GROUP BY (SQL: select * from messages where (from = 9) or (to = 9) group by from)

у тебе и название табле from ?

Похожие вопросы

Обсуждают сегодня

Кстати, а я вот тут подумал. Допустим, у нас имеется цикл который выполняет огромное количество итераций, но мы хотим, чтобы какие-то действия исполнилось только один раз. В Я...
The Bird of Hermes
23
Доброй ночи. Вопрос знатокам. Имеется некая таблица, результат которой выведен в DBGrid на форме. И есть форма, с помощью которой можно как добавить запись, так и отредактиров...
Евгений
28
а всё почему? потому что ассемблер в отличии от яву порождает множество пагубных привычек, среди которых например можно отметить использование глобальных переменных для всего ...
Mixail Frolov
35
анрей С какой целью зашёл?
КТ315
42
я часов 15 назад начал пытаться написать хоть что-то напоминающее ос и у меня есть проблема, которую я пытаюсь решить последние часов 5: есть крч 2 исходника с минимальным код...
Al1to
17
Кто нибудь из участников чата пишет на ассемблере под GNU/Linux?
Spiker01
24
Всем привет ребят! Мб кто-то сталкивался? adminСomponents .get("searchСomponents", use: searchComponents) .openAPI( summary: ...
Admin Adminov
2
Насколько моя реализация Exercise 1 плохая? data MessageType = Info | Warning | Error Int deriving (Show, Eq) type TimeStamp = Int data LogMessage = LogMessage ...
= ?
10
Кстати вопрос. Проанализировав свои проекты я понял, что в наиболее ценных из них Асм использовался для организации real-time процессов (внутри DOS). А какие есть способы сего...
Alexander Morozov
18
Я не очень много работал с потоками, тут возник вопрос - если будет одновременный доступ к памяти из двух разных потоков, это само по себе приведет к ошибке?
The Bird of Hermes
25
Карта сайта