Normal JOIN ... ON ...
sözdizimi iyi bilinmektedir. Ancak, ON
maddeyi yazdıklarından ayrı olarak yerleştirmek de mümkündür JOIN
. Bu, pratikte nadir görülen, öğreticilerde bulunmayan bir şeydir ve bunun mümkün olabileceğinden bahseden herhangi bir web kaynağı bulamadım .
İşte oynayabileceğiniz bir betik:
SELECT *
INTO #widgets1
FROM (VALUES (1), (2), (3)) x(WidgetID)
SELECT *
INTO #widgets2
FROM (VALUES (1, 'SomeValue1'), (2, 'SomeValue2'), (3, 'SomeValue3')) x(WidgetID, SomeValue)
SELECT *
INTO #widgetProperties
FROM (VALUES
(1, 'a'), (1, 'b'),
(2, 'a'), (2, 'b'))
x(WidgetID, PropertyName)
--q1
SELECT w1.WidgetID, w2.SomeValue, wp.PropertyName
FROM #widgets1 w1
LEFT JOIN #widgets2 w2 ON w2.WidgetID = w1.WidgetID
LEFT JOIN #widgetProperties wp ON w2.WidgetID = wp.WidgetID AND wp.PropertyName = 'b'
ORDER BY w1.WidgetID
--q2
SELECT w1.WidgetID, w2.SomeValue, wp.PropertyName
FROM #widgets1 w1
LEFT JOIN #widgets2 w2 --no ON clause here
JOIN #widgetProperties wp
ON w2.WidgetID = wp.WidgetID AND wp.PropertyName = 'b'
ON w2.WidgetID = w1.WidgetID
ORDER BY w1.WidgetID
--q3
SELECT w1.WidgetID, w2.SomeValue, wp.PropertyName
FROM #widgets1 w1
LEFT JOIN (
#widgets2 w2 --no SELECT or FROM here
JOIN #widgetProperties wp
ON w2.WidgetID = wp.WidgetID AND wp.PropertyName = 'b')
ON w2.WidgetID = w1.WidgetID
ORDER BY w1.WidgetID
q1 normal görünüyor. q2 ve q3, fıkraların olağandışı konumlarına sahiptir ON
.
Bu senaryo mutlaka anlam ifade etmiyor. Anlamlı bir senaryo benim için zordu.
Peki bu olağandışı sözdizimi kalıpları ne anlama geliyor? Bu nasıl tanımlanır? İki ON
maddenin tüm pozisyonlarına ve siparişlerine izin verilmediğini fark ettim . Bunu düzenleyen kurallar nelerdir?
Ayrıca böyle sorular yazmak hiç iyi bir fikir değil mi?