powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Нужна помощь в запросе
5 сообщений из 5, страница 1 из 1
Нужна помощь в запросе
    #38984711
Фотография meg17m
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Есть запрос на выборку юзернейма, емейла, ника, даты регистрации партнера, а так же кол-ва регистраций приведенных им игроков, общей суммы депозитов игроков партнера и даты последнего депозита. Вот он запрос:
Код: sql
1.
2.
3.
4.
5.
SELECT u.username, u.email, up.nick, up.created_at, COUNT(p.id) as regs, SUM(t.amount) as deps, MAX(t.created_at) as maxt
                                                               FROM users u LEFT JOIN users_profile up ON u.id = up.user_id LEFT JOIN players p ON p.partner_id = u.id
                                                                            LEFT JOIN transactions t ON t.user_id = p.user_id
                                                                WHERE t.project_id = p.project_id and t.direction = 1
                                                                GROUP BY u.id


Но он не выводит партнеров, у которых вовсе нет привлеченных игроков с депозитами, а нужно, чтобы выводил. Выводит только тех, у кого есть игроки. Думал, ЛЕФТ ДЖОЙН поможет, - не помог. Как нужно переписать запрос, чтобы он выводил абсолютно всех пользователей из таблицы юзерс и ставил в поля regs и deps нули, если таковых (игроков с депозитами) нет?
...
Рейтинг: 0 / 0
Нужна помощь в запросе
    #38984729
Фотография MasterZiv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
MegaLasta,

Ты тут УБИЛ LEFT JOIN, превратив его в INNER JOIN.

Все условия на таблицы, которые в LEFT JOIN надо писать во фразе LEFT JOIN ... ON ,
а не в WHERE.

Код: sql
1.
2.
3.
4.
5.
6.
SELECT u.username, u.email, up.nick, up.created_at, COUNT(p.id) as regs, SUM(t.amount) as deps, MAX(t.created_at) as maxt
FROM users u 
LEFT JOIN users_profile up ON u.id = up.user_id 
LEFT JOIN players p ON p.partner_id = u.id
LEFT JOIN transactions t ON t.user_id = p.user_id and t.project_id = p.project_id and and t.direction = 1
GROUP BY u.id
...
Рейтинг: 0 / 0
Нужна помощь в запросе
    #38984738
tanglir
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
MasterZivВсе условия на таблицы, которые в LEFT JOIN надо писать во фразе LEFT JOIN ... ON ,
а не в WHERE.да тут ещё вопрос, куда ТСу НСД надо было писать все эти условия и понимал ли он вообще, зачем ему левый, а не "обычный" джойн
...
Рейтинг: 0 / 0
Нужна помощь в запросе
    #38984740
Фотография meg17m
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
спасибо
...
Рейтинг: 0 / 0
Нужна помощь в запросе
    #38984779
Фотография MasterZiv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
tanglirMasterZivВсе условия на таблицы, которые в LEFT JOIN надо писать во фразе LEFT JOIN ... ON ,
а не в WHERE.да тут ещё вопрос, куда ТСу НСД надо было писать все эти условия и понимал ли он вообще, зачем ему левый, а не "обычный" джойн

Я смотрел на запрос пока чисто механически.
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Нужна помощь в запросе
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]