|
|
|
Выборка пользователей со сложным условием
|
|||
|---|---|---|---|
|
#18+
Задача: Нужно составить запрос так чтобы выводил всех пользователей сайта кроме тех, что есть в друзьях авторизованного пользователя и эво самого. Есть две таблицы: Первая user - список пользователей сайта Вторая friends - связь двух пользователей которые являются друзьями Таблица user имеет колонки: id_сер - id пользователя name - имя пользователя Таблица friends имеет колонки: id_s - id пользователя который отправил запрос на дружбу id_f - id пользователя принявший запрос на дружбу То что я на данный момент составил: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. $user_id - id авторизованного пользователя Проблемы которые возникли: 1. Одни и те же пользователи выводятся несколько раз 2. Если пользователь не имеет еще друзей то в списке выводится и он (Знаю как решить). Вопрос: 1. Можно составить запрос более производительним? Если да, то как? 2. Если логика запроса правильная то как решить Вышеперечисленные проблемы? Приоритеты: 1.Время выполнения запроса 2.Количество занимаемого места ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 03.06.2016, 00:18 |
|
||
|
Выборка пользователей со сложным условием
|
|||
|---|---|---|---|
|
#18+
Код: sql 1. 2. 3. 4. 5. 6. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 04.06.2016, 19:08 |
|
||
|
|

start [/forum/topic.php?fid=47&fpage=99&tid=1831697]: |
0ms |
get settings: |
6ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
99ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
33ms |
get tp. blocked users: |
2ms |
| others: | 230ms |
| total: | 404ms |

| 0 / 0 |
