排序合并法(SORT- MERGE 常用于=连接 ■首先按连接属性对表1和表2排序 ■对表1的第一个元组,从头开始扫描表2,顺序查找 满足连接条件的元组,找到后就将表1中的第一个 元组与该元组拼接起来,形成结果表中一个元组 遇到表2中第一条大于表1连接字段值的元组时, 对表2的查询不再继续 An Introduction to Database System
An Introduction to Database System 排序合并法(SORT-MERGE) 常用于=连接 ◼ 首先按连接属性对表1和表2排序 ◼ 对表1的第一个元组,从头开始扫描表2,顺序查找 满足连接条件的元组,找到后就将表1中的第一个 元组与该元组拼接起来,形成结果表中一个元组。 当遇到表2中第一条大于表1连接字段值的元组时, 对表2的查询不再继续
排序合并法 ■找到表1的第二条元组,然后从刚才的中断点处继 续顺序扫描表2,查找满足连接条件的元组,找到 后就将表1中的第一个元组与该元组拼接起来,形 成结果表中一个元组。直接遇到表2中大于表1连接 字段值的元组时,对表2的查询不再继续 重复上述操作,直到表1或表2中的全部元组都处理 完毕为止 An Introduction to Database System
An Introduction to Database System 排序合并法 ◼ 找到表1的第二条元组,然后从刚才的中断点处继 续顺序扫描表2,查找满足连接条件的元组,找到 后就将表1中的第一个元组与该元组拼接起来,形 成结果表中一个元组。直接遇到表2中大于表1连接 字段值的元组时,对表2的查询不再继续 ◼ 重复上述操作,直到表1或表2中的全部元组都处理 完毕为止
索引连接( INDEX-JoIN) ■对表2按连接字段建立索引 ■对表1中的每个元组,依次根据其连接字段 值查询表2的索引,从中找到满足条件的元 组,找到后就将表1中的第一个元组与该元 组拼接起来,形成结果表中一个元组 An Introduction to Database System
An Introduction to Database System 索引连接(INDEX-JOIN) ◼ 对表2按连接字段建立索引 ◼ 对表1中的每个元组,依次根据其连接字段 值查询表2的索引,从中找到满足条件的元 组,找到后就将表1中的第一个元组与该元 组拼接起来,形成结果表中一个元组
连接查询(续) SQL中连接查询的主要类型 广义笛卡尔积 等值连接(含自然连接) ■非等值连接查询 自身连接查询 外连接查询 复合条件连接查询 An Introduction to Database System
An Introduction to Database System 连接查询 (续) SQL中连接查询的主要类型 ◼ 广义笛卡尔积 ◼ 等值连接(含自然连接) ◼ 非等值连接查询 ◼ 自身连接查询 ◼ 外连接查询 ◼ 复合条件连接查询
广义笛卡尔积 不带连接谓词的连接 很少使用 例 select Student sc x FROM Student sc An Introduction to Database System
An Introduction to Database System 一、广义笛卡尔积 ◼ 不带连接谓词的连接 ◼ 很少使用 例: SELECT Student.* , SC.* FROM Student, SC