详解SQL Server数据库链接查询的方式


当前第2页 返回上一页

3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列.

例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社:

SELECT *  
FROM authors AS a INNER JOIN publishers AS p  
ON a.city=p.city  
SELECT a.*,p.pub_id,p.pub_name,p.country  
FROM authors AS a INNER JOIN publishers AS p  
ON a.city=p.city 

又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state):

(二)外连接

内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。

1、left join或left outer join(左外连接)

左外连接:(也叫左外连接,给出两个表的配匹行,并且以左边的表为准,如果左边表有而右边表没有的行,则在右边表的相应行选择的列显示为NULL,允许左边的基准表对应右边表多条满足条件的记录)左连接就是返回左边的匹配行,不考虑右边的表是否有相应的行

select field1,field2 from table1 left join table2 
on field1=field2(基准字段,可以多个) 
where table1.field3=table2.field3 

2、right join或right outer join(右外连接)

右连接:(也叫右外连接,给出两个表的配匹行,并且以右边的表为准,如果右边表有而左边表没有的行,则在右边表的相应行选择的列显示为NULL,允许右边的基准表对应左边表多条满足条件的记录)

语法与做链接差不多!

(三)交叉连接

交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等于6*8=48行。

SELECT type,pub_name  
FROM titles CROSS JOIN publishers  
ORDER BY type 

关于SQL Server数据库链接查询的方式的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

更多SQL内容来自木庄网络博客


标签:SQL

返回前面的内容

相关阅读 >>

sql为什么会出现无效的列索引

delete和truncate之间的差别有哪些

sql insert语句怎么写

常用的sql数据库有哪些

数据库中的内容字段被挂马的替换方法 sql注入

sql server优化50法汇总

sql中 decode()函数简介

mssql中having的用处详解

只会sql能找什么工作?

整理一下sqlserver的排序规则

更多相关阅读请进入《sql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...