Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Запрос в 3 таблицы.

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Predator
Отправлено: 23 Июня, 2012 - 17:35:13
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


Суть в том чтоб сделать вывод аватаров топиков.
Точно не знаю.
Можно ли сделать запрос к 3 таблицам так чтоб к каждому автору был верный аватар?
Или нужно делать еще 1 запрос , но с фильтрацией по автору?
 
 Top
DeepVarvar Супермодератор
Отправлено: 23 Июня, 2012 - 17:37:45
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Можно.
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT x.a, y.b, z.c
  2.   FROM tbl1 x
  3.   [LEFT] JOIN tbl2 y ON y.xk = x.k
  4.   [LEFT] JOIN tbl3 z ON z.yk = y.k
  5.   [WHERE] ...
 
 Top
Predator
Отправлено: 23 Июня, 2012 - 18:11:27
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


PHP:
скопировать код в буфер обмена
  1. SELECT * FROM `forums`
  2. LEFT JOIN `topics` ON forums.id = topics.forum_id
  3. LEFT JOIN `users` ON forums.id = topics.forum_id
  4.  WHERE LB_forums.id IN (66,65,67)


Так правильно будит?

(Отредактировано автором: 23 Июня, 2012 - 18:12:06)

 
 Top
DeepVarvar Супермодератор
Отправлено: 23 Июня, 2012 - 18:36:35
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT [перечисли выбираемые поля, лишних не нужно]
  2.   FROM forums
  3.   LEFT JOIN topics ON forums.id = topics.forum_id
  4.   LEFT JOIN users ON forums.id = topics.forum_id
  5.   WHERE /*LB_ что это? его выше нигде нет */ forums.id IN(66,65,67)

(Добавление)
и я бы не советовал играть с пробелами после IN, CONCAT и пр...
Лучше пиши сразу скобку после оператора, это не php.

(Отредактировано автором: 23 Июня, 2012 - 18:38:29)

 
 Top
Predator
Отправлено: 23 Июня, 2012 - 18:48:26
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


PHP:
скопировать код в буфер обмена
  1. SELECT *
  2.   FROM forums
  3.   LEFT JOIN topics ON forums.id = topics.forum_id
  4.   LEFT JOIN users ON forums.id = topics.forum_id
  5.   WHERE forums.id NOT IN (17,16,18,65,79,65,78,82,81,77,83,54,5,20,66,67)


Зачем перечислять нужные поля?Не разу не делал так.
Вот щас результат таков:
Выводи один и тот же топик, а аватарка только у 1.Что не так в запросе?
(Добавление)
Хелп люди. Растерялся
 
 Top
Panoptik
Отправлено: 23 Июня, 2012 - 20:05:04
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2493
Дата рег-ции: Нояб. 2011  
Откуда: Одесса, Украина


Помог: 131 раз(а)




таблица юзерс соединяется неверно
не указан внешний ключ таблицы в выражении ON


-----
Just do it
 
 Top
Predator
Отправлено: 23 Июня, 2012 - 20:11:51
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


Что за внешний ключ таблицы, скажи пожалуйста. Как узнать?

(Отредактировано автором: 23 Июня, 2012 - 20:17:37)

 
 Top
tuareg
Отправлено: 23 Июня, 2012 - 20:37:21
Post Id


Участник


Покинул форум
Сообщений всего: 1234
Дата рег-ции: Июнь 2010  


Помог: 69 раз(а)




Predator пишет:
Что за внешний ключ таблицы, скажи пожалуйста. Как узнать?

Надо внимательней быть
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. SELECT *
  3.   FROM forums
  4.   LEFT JOIN topics ON forums.id = topics.forum_id
  5.   LEFT JOIN users ON forums.id = users.forum_id
  6.   WHERE forums.id NOT IN (17,16,18,65,79,65,78,82,81,77,83,54,5,20,66,67)
  7.  
 
 Top
Predator
Отправлено: 23 Июня, 2012 - 20:48:52
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


Не получается.

(Отредактировано автором: 23 Июня, 2012 - 21:30:18)

 
 Top
DeepVarvar Супермодератор
Отправлено: 23 Июня, 2012 - 21:29:25
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Ну а в форуме есь айдишник юзера?
Вообще есть ключики для связи?
Если нет, то значит база не правильно спроектирована.
 
 Top
Predator
Отправлено: 23 Июня, 2012 - 21:30:25
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


Не то все, протрезвел и понял:
PHP:
скопировать код в буфер обмена
  1.  
  2. SELECT *
  3.   FROM forums
  4.   LEFT JOIN topics ON forums.id = topics.forum_id
  5.   LEFT JOIN users ON topics.last_post_member = users.name
  6.   WHERE forums.id NOT IN (17,16,18,65,79,65,78,82,81,77,83,54,5,20,66,67)
  7.  


В таблице user поле name, должно совпадать с полем last_post_member из таблице topics. И все равно не получается,

Должно выдать аватарку пользователя но её нет, что то не так. Тогда что неправильно когда все правильно? Хм
 
 Top
DeepVarvar Супермодератор
Отправлено: 23 Июня, 2012 - 21:33:57
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Predator пишет:
topics.last_post_member = users.name
'Вася' == 'васЯ' для регистронезависимых.
Точно - пересмотреть структуру базы.
 
 Top
Predator
Отправлено: 23 Июня, 2012 - 21:44:58
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 619
Дата рег-ции: Март 2012  
Откуда: Ярославль


Помог: 0 раз(а)

[+][+][+]


Спс поставил на того кто открыл тему все хорошо, но мне нужно поставить на того кто ответил последний.А тат как у тех тем у которых нет еще ответов соответственно и поле last_post_member пустое.
Вопрос в следующем.
Как сделать так чтоб при отсутствии в поле (last_post_member) значений бралось из поля member_name_open.
И наоборот. Есть функция для такого?
 
 Top
DeepVarvar Супермодератор
Отправлено: 23 Июня, 2012 - 23:14:10
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Вынести условие из ON в WHERE и там использовать OR или NOT NULL...
А на самом деле чем дальше в лес тем крупнее воробьи.
Я все же советую пересмотреть структуру БД, лучше добавить еще таблиц со связями чем мучаться со сложными условиями выборки.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB