数 据 库 表 与 表 连 接 的 方 式 (内 连 接 、外连 接 [左连 接 、右连 接 、全连 接 ]、交叉连 接 ) 连接查询方式有: 内连接、外连接(左连接、右连接、全连接)、交叉连接 左连接和右连接的区别: 左连接以左表为基准进行查询,左表数据会全部显示出来,右表如果和左表匹配的数据则显示相应字段的数据,如果不匹配,则显示为 NULL;右连接刚好相反。 全连接就是先以左表进行左外连接,然后以右表进行右外连接。 说明:所谓的基本,就是以某张表的限制条件查询条件为准! 具体如下: 一、内连接 内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种: 1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。 2、不等连接:在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>。 3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。 二、外连接 返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 三、交叉连接 交叉连接不带 WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。例,titles 表中有6 类图书,而 pu blishers 表中有8 家出版社,则下列交叉连接检索到的记录数将等于 6*8=48 行。 第二部分、实例说明 实例 Book 表: Stu dent 表: 一、内连接 select * from [Book] as b,[Student] as s w here b.StudentId=s.StudentId 等价于如下(也可以不要关键字 inner,此为系统默认) select * from [Book] as b inner join [Student] as s ON b.StudentId=s.StudentId 结果为: 执行过程 相当于内连接的向右连接。以 from [Book] inner join [Student]等式右边为基准,即以 Student表(等式右表,s 表)的 s.StudentId 为基准,遍历 Book 表(等式左表,Book 表)中与之匹配的 b.StudentId,然后拼接返回。结果含有重复的列,b.StudentId 和 s.StudentId。 说明 这与w...