У меня есть следующие таблицы в PostgreSQL:
Categories | Locations | Checkins | Users | Friendships
id | id | id | id | user_id
name | category_id | location_id | gender | friend_id
icon | name | user_id | |
Теперь я хочу получить следующую информацию о месте проведения
- Сколько пользователей женского и мужского пола в местоположенииимеет
- Название категории и значок
- Название местоположения
- Сколько друзей зарегистрировалось в определенном месте (с заданным идентификатором пользователя)
Кроме последнего пункта, я решил это.Но у меня проблемы с подсчетом друзей по заданному идентификатору пользователя.Я попробовал это с этим запросом:
SELECT distinct locations.id,
max(locations.name) as name,
max(locations.location) as location,
max(categories.name) as cat,
max(categories.icon) as caticon,
SUM(CASE WHEN users.gender = 'm' THEN 1 ELSE 0 END) AS male,
SUM(CASE WHEN users.gender = 'f' THEN 1 ELSE 0 END) AS female,
SUM(CASE WHEN friendships.user_id = 1 OR friendships.friend_id=1 THEN 1 ELSE 0 END) AS friends
FROM locations
INNER JOIN checkins ON checkins.location_id = locations.id
INNER JOIN users ON users.id = checkins.user_id
INNER JOIN categories ON categories.id = locations.category_id
LEFT JOIN friendships ON friendships.user_id = users.id OR friendships.friend_id = users.id
WHERE locations.id=7
GROUP BY locations.id
Но я получаю неправильный номер счета для женщин-пользователей.Есть идеи, что я делаю не так?Я думаю, что мне нужно левое соединение для таблицы дружбы, потому что, если у пользователя нет друзей (или пользователь не указан), он должен возвращать только 0 для количества друзей.
Надеюсь, я ясно дал понять, спасибо,пингвин