Re: Помогите начинающему.

From
Vladimir Pavlikov (2:5020/400)
To
Vladimir Ilyashenko
Date
2006-02-24T18:09:32Z
Area
SU.DBMS.SQL
From: "Vladimir Pavlikov" <vvp@soil.msu.ru>

Hello, Vladimir!
You wrote to Pavel Korzan on Thu, 23 Feb 2006 17:54:59 +0300:

 VI> Извини за назойливость, но если найдется время, объясни логику вот
 VI> этого "...INNER JOIN TAB2 ON...". Не нашел я ничего подобного в
 VI> имеющихся у меня учебниках, а в интернете только ссылки на ссылки по
 VI> кругу в одни и те же источники, результат изучения которых - на лицо :(
 VI> Или ссылочку конкретную, если есть.

Любой источник по языку sql. А не доку к конкретному движку, хотя
документация к большинству тоже должна содержать формальный
синтаксис. Грабера почитай, на http://citforum.ru/ поищи статьи Кузнецова.
Ну а если коротко...
Запросы, в которые входит более одной таблицы - это объединения
(join). Бывают внешние, при этом полные, левые или правые
( outer [full | left | right] join ), или внутренние - inner. Это, так 
сказать,
канонические ("правильные") формы записи. А запись с перечислением
таблиц - это сокращенная форма внутреннего (inner) объединения. Я
использую именно каноническую форму просто потому, что она
позволяет явно указать поля объединения в конструкции on. В короткой
форме все валится в кучу : и условия объединения, и ограничения -
все перечисляются сплошняком в where. Т.е. конструкции ниже
эквивалентны, но первая короче, а вторая лучше :)

select t1.*
from t1, t2
where t1.x = t2.x and t2.y = 8;

select t1.*
from t1 inner join t2
on t1.x = t2.x
where t2.y = 8;

With best regards, Vladimir Pavlikov.  E-mail: vvp@soil.msu.ru 


-- 
Отправлено через сервер Форумы@mail.ru - http://talk.mail.ru
--- ifmail v.2.15dev5.3
 * Origin: Talk.Mail.Ru (2:5020/400)
SEEN-BY: 46/50 50/12 203 520 450/159 186 1024 451/30 454/9 461/43 132 640
SEEN-BY: 469/999 4614/20 4616/3 4625/8 4627/10 4641/444 5000/76 5000 5001/5001
SEEN-BY: 5006/1 5007/1 5010/53 70 5011/13 5012/23 46 5015/28 5019/31 5020/86
SEEN-BY: 5020/175 194 400 545 604 639 715 758 830 892 982 1042 1057 1200 1523
SEEN-BY: 5020/1604 1665 1909 1922 2013 2020 2238 4441 5021/3 29 5022/128
SEEN-BY: 5025/3 750 5026/10 14 45 5027/12 5029/32 5030/115 217 436 473 556 966
SEEN-BY: 5030/1063 1339 1900 5034/13 5035/38 5036/1 5040/47 5042/13 5045/7
SEEN-BY: 5047/47 5049/1 5051/15 5053/16 5054/1 8 9 28 35 37 45 63 67 5055/95
SEEN-BY: 5057/1 5059/9 5060/88 5061/15 5062/1 5066/18 5070/1222 5077/70
SEEN-BY: 5080/68 1003 5081/2 5082/6 5083/21 5084/32 5085/13 5090/106 5093/27
SEEN-BY: 5095/20 5099/133 6000/1 12 6009/1
PATH: 5020/400 4441 545 5054/1 37