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 :: Вопрос по объединению таблиц БД

 PHP.SU

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


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

> Без описания
teddy
Отправлено: 08 Июня, 2013 - 23:23:07
Post Id


Участник


Покинул форум
Сообщений всего: 1462
Дата рег-ции: Апр. 2013  


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




Доброй ночи ) искал с помощью поиска по форуму, но не нашел именно то, что мне нужно... Ранее не занимался объединением таблиц БД при помощи JOIN, интересует несколько вопросов, если кто знает, подскажите, пожалуйста )

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


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

Если можно подскажите, буду благодарен )

(Отредактировано автором: 09 Июня, 2013 - 00:14:11)

 
 Top
Мелкий Супермодератор
Отправлено: 08 Июня, 2013 - 23:35:48
Post Id



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


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




teddy пишет:
Ещё видел LEFT JOIN, RIGHT JOIN и т.д - в каких случаях и как срабатывает запрос?

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

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

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

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

В общем случае - да.


-----
PostgreSQL DBA
 
 Top
teddy
Отправлено: 08 Июня, 2013 - 23:42:25
Post Id


Участник


Покинул форум
Сообщений всего: 1462
Дата рег-ции: Апр. 2013  


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




Спасибо за ссылку и подсказку )

(Отредактировано автором: 08 Июня, 2013 - 23:50:52)

 
 Top
Мелкий Супермодератор
Отправлено: 08 Июня, 2013 - 23:51:17
Post Id



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


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Не может быть, специально проверил, на месте и ссылка и статья в ней.
Если коротко - left join берёт все строки из первой таблицы и по условию объединяет со второй таблицей. Если условию ни одна строка второй таблицы не удовлетворяет - поля из первой таблицы будут на месте, а вместо полей второй таблицы - null'ы. right join - то же самое, но в обратном порядке таблиц.


-----
PostgreSQL DBA
 
 Top
teddy
Отправлено: 09 Июня, 2013 - 00:02:55
Post Id


Участник


Покинул форум
Сообщений всего: 1462
Дата рег-ции: Апр. 2013  


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




Мелкий
Да, ссылка работает ) Это у меня комп тупанул, сори ) И спасибо ещё раз Подмигивание
(Добавление)
Мелкий пишет:
Если коротко - left join берёт все строки из первой таблицы и по условию объединяет со второй таблицей.

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

(Отредактировано автором: 09 Июня, 2013 - 00:16:24)

 
 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