Практическая лабораторная работа №1


Использование перекрестных соединений


Download 3.23 Mb.
Pdf ko'rish
bet133/207
Sana16.11.2023
Hajmi3.23 Mb.
#1778259
TuriУчебно-методическое пособие
1   ...   129   130   131   132   133   134   135   136   ...   207
Bog'liq
курс лаб по SQL 2008

 
Использование перекрестных соединений 
Перекрестное соединение, не имеющее предложения WHERE, выполняет 
декартово произведение таблиц, вовлеченных в объединение. Размер результирующего 
набора декартова произведения вычисляется, как произведение количества строк в 
первой таблице на количество строк во второй таблице. Следующий пример показывает 
перекрестное соединение Transact-SQL. 
SELECT KAFEDRA.Name_Kafedru AS 'название кафедры', 
TEACHER.NAME_TEACHER AS 'фамилия преподавателя'
FROM KAFEDRA CROSS JOIN TEACHER 
ORDER BY KAFEDRA.kod_kafedru;  
Результирующий набор содержит 297 строк (в KAFEDRA имеется 11 строк, а в таблице 
TEACHER существует 27 строк; 11, умноженное на 27, равно 297). 
 
Внешнее соединение трех и более таблиц 
В запросе может быть использовано внешнее соединение более чем двух таблиц.
Хотя в операции соединения указываются всего две таблицы, предложение FROM 
может содержать несколько операций объединения. Это позволяет соединять в одном 
запросе несколько таблиц. 
При этом следует помнить, что если к столбцу таблицы А применен оператор 
внешнего соединения с таблицей В, то никакой другой столбец таблицы А не может 
содержать оператор внешнего соединения с таблицей, отличающейся от В.
В следующем примере внешнее соединение применяется для трех таблиц — 
факультетов, кафедр и преподавателей. 
Запрос 47. Вывести список всех факультетов с указанием их кафедр и 
преподавателей. 
 
SELECT f.NAME_FACULTETA AS 'Факультет', 
k.Name_Kafedru AS 'Кафедра', 
t.NAME_TEACHER AS 'Преподаватель'
FROM FACULTET f JOIN KAFEDRA k
ON f.kod_faculteta =k.kod_faculteta 
JOIN TEACHER t
ON k.kod_kafedru = t.kod_kafedru; 


129 
Следующий запрос Transact-SQL выполняет поиск наименований всех факультетов 
определенной кафедры и имена преподавателей этих кафедр. 
Обратите внимание, что ни один из соединяемых столбцов — ни kod_faculteta, ни 
kod_kafedru, не включается в результаты. Тем не менее, соединение возможно только при 
использовании Kafedrа в качестве промежуточной таблицы. 
Среднюю таблицу соединения, Kafedrа, можно назвать таблицей преобразования, 
или промежуточной таблицей, так как Kafedrа является промежуточной точкой 
объединения, которая находится между двумя другими участвующими в объединении 
таблицами. 
При наличии в инструкции нескольких операторов соединения, применяющихся 
либо при соединении более двух таблиц, либо при соединении более двух пар столбцов, 
выражения соединения могут быть связаны операторами AND или OR. 

Download 3.23 Mb.

Do'stlaringiz bilan baham:
1   ...   129   130   131   132   133   134   135   136   ...   207




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©fayllar.org 2024
ma'muriyatiga murojaat qiling