Forum Webscript.Ru
Общие => Базы данных => Тема начата: volod от 08 Февраля 2005, 11:35:45
-
Кто бы вот так внятно смог объяснить, как вообще работает JOIN и чем он принципиально отличается от запято и., LEFT JOIN.
Или ссылку киньте на кой-то ресурс. Вот только этой (http://dev.mysql.com/doc/mysql/ru/join.html) не нужно! Написано там классно, но чуток не то. Механизма, механизма тама нету...
-
Все, нашел.
http://citforum.novgorod.net/database/dblearn/dblearn05.shtml
Все свободны, всем спасибо:)
-
Нет. Все-таки нашел, но не то.
Таки не роздуплил, чем концептуально отличаются, ну хотя бы LEFT JOIN и INNER JOIN?..
:/
-
volod
INNER JOIN - выбираются ТОЛЬКО те записи из обоих таблиц которые удовлетворяют условию.
LEFT JOIN - Выбираются ВСЕ записи из первой таблицы; из второй таблицывыбираются ТОЛЬКО те записи, которые удовлетворяют условию.
Вообще попробовал бы у себя поэкспериментировать, иначе этот "чупа-чупс" будем долго обсасывать...
-
********************************************************
mysql> explain SELECT
-> m.id_membership, m.code,
-> p.price
-> FROM memberships AS m
-> LEFT JOIN membership_programs AS p ON (p.id_membership = m.id_membership AND p.suspended = 0)
-> WHERE m.id_membership = 2 AND suspended = 0 AND site = "MS"
-> ;
+----+-------------+-------+-------+------------------------------------------------------------+--------------------------+---------+-------+------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+-------+------------------------------------------------------------+--------------------------+---------+-------+------+-------------+
| 1 | SIMPLE | m | const | PRIMARY,XAK1_memberships,XAK2_memberships,XFK1_memberships | PRIMARY | 4 | const | 1 | |
| 1 | SIMPLE | p | ref | XFK1_membership_programs,XIE1_membership_programs | XFK1_membership_programs | 4 | const | 2 | Using where |
+----+-------------+-------+-------+------------------------------------------------------------+--------------------------+---------+-------+------+-------------+
2 rows in set (0.02 sec)
*****************************************************
********* и ПОЧТИ такой же но INNER *******************
*****************************************************
mysql> explain SELECT
-> m.id_membership, m.code,
-> p.price
-> FROM memberships AS m
-> INNER JOIN membership_programs AS p ON (p.id_membership = m.id_membership AND p.suspended = 0)
-> WHERE m.id_membership = 2 AND suspended = 0 AND site = "MS"
-> ;
+----+-------------+-------+-------+------------------------------------------------------------+--------------------------+---------+-------+------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+-------+------------------------------------------------------------+--------------------------+---------+-------+------+-------------+
| 1 | SIMPLE | m | const | PRIMARY,XAK1_memberships,XAK2_memberships,XFK1_memberships | PRIMARY | 4 | const | 1 | |
| 1 | SIMPLE | p | ref | XFK1_membership_programs,XIE1_membership_programs | XFK1_membership_programs | 4 | const | 2 | Using where |
+----+-------------+-------+-------+------------------------------------------------------------+--------------------------+---------+-------+------+-------------+
2 rows in set (0.00 sec)
********************************************************
Найдите десять отличий! Или я плохо смотрю?..
Каррроче, експлейн на всю эту фигню что тама что тама выдет для таблицы memberships AS m (которая, обратите ка ваше внимание, стоит в начале произведения) тип связывания CONST. !
Ну это ж никак ни ALL...
-
volod
Я что-то не понял... то ты начинаешь "умничать" про индексы то не можешь понять разницу между INNER JOIN и LEFT JOIN...
В чем отличие, я тебе сказал, отличия в результатах запроса - даже смотреть не буду, ты вообще не понимаешь о чем идет речь...
Если тебе это не нужно не заморачивайся, все равно не поймешь...
Т.к. в той же документации MySQL, ссылку на которую ты же сам и дал, все написано...
-
Эхе-хе... Ну ладно. Не знаешь, как объяснить, либо не хочешь, так чего ж заводиться? Я и сам начитан, но нафиг мне эта теория, если я вот на EXPLAN смотрю, а он мне говорит: "Чувак, а запросики, че ты мне подсовываешь, есьм одинаковые". И вот как раз про этот случай я говорю.
Ладно. Если никто больше не объяснит это вот явление, сам как-нибуть додую.
Спасибо, Phoenix.