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
Форумы портала PHP.SU :: Версия для печати :: Вопрос по объединению таблиц БД
Форумы портала PHP.SU » » Вопросы новичков » Вопрос по объединению таблиц БД

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

1. teddy - 08 Июня, 2013 - 23:23:07 - перейти к сообщению
Доброй ночи ) искал с помощью поиска по форуму, но не нашел именно то, что мне нужно... Ранее не занимался объединением таблиц БД при помощи JOIN, интересует несколько вопросов, если кто знает, подскажите, пожалуйста )

Вариант 1:
PHP:
скопировать код в буфер обмена
  1. $mysqli->query("SELECT item, price FROM items, prices");


Это одно и тоже что и если использовать JOIN? Если да, то чем первый отличается от JOIN-а? Ещё видел LEFT JOIN, RIGHT JOIN и т.д - в каких случаях и как срабатывает запрос? ) ещё видел ключевое слово ON... Т.е с JOIN не работал вообще... Не знаю точно как составлять такие запросы, последовательность написания операторов, полей и т.д

Если можно подскажите, буду благодарен )
2. Мелкий - 08 Июня, 2013 - 23:35:48 - перейти к сообщению
teddy пишет:
Ещё видел LEFT JOIN, RIGHT JOIN и т.д - в каких случаях и как срабатывает запрос?

У меня вот такая вот ссылка в закладках завалялась: http://www[dot]codinghorror[dot]com/blog[dot][dot][dot]f-sql-joins[dot]html

teddy пишет:
ещё видел ключевое слово ON...

Непосредственно условие, по которому надо присоединять таблицы - какой строке одной какие строки второй должны быть сопоставлены.
Без условия - декартово произведение, к каждой строке первой таблицы присоединяется каждая строка второй. Нужно такое только в весьма исключительных случаях, обычно - ошибка.

teddy пишет:
Это одно и тоже что и если использовать JOIN?

В общем случае - да.
3. teddy - 08 Июня, 2013 - 23:42:25 - перейти к сообщению
Спасибо за ссылку и подсказку )
4. Мелкий - 08 Июня, 2013 - 23:51:17 - перейти к сообщению
Не может быть, специально проверил, на месте и ссылка и статья в ней.
Если коротко - left join берёт все строки из первой таблицы и по условию объединяет со второй таблицей. Если условию ни одна строка второй таблицы не удовлетворяет - поля из первой таблицы будут на месте, а вместо полей второй таблицы - null'ы. right join - то же самое, но в обратном порядке таблиц.
5. teddy - 09 Июня, 2013 - 00:02:55 - перейти к сообщению
Мелкий
Да, ссылка работает ) Это у меня комп тупанул, сори ) И спасибо ещё раз Подмигивание
(Добавление)
Мелкий пишет:
Если коротко - left join берёт все строки из первой таблицы и по условию объединяет со второй таблицей.

Кстати, получается что это дело можно заменить при помощи WHERE если использовать первый вариант?

 

Powered by ExBB FM 1.0 RC1