SQL数据库查询语句问题

请问一下SQL中什么时候该用innerjoin,什么时候要用left/right join呢??有没有比较好懂的例子?最近在写这些东西的时候没能搞懂,困扰了很久... 请问一下SQL中什么时候该用inner join,什么时候要用left/right  join 呢??有没有比较好懂的例子?最近在写这些东西的时候没能搞懂,困扰了很久了!! 展开
 我来答
boyhaxin
2011-12-08 · TA获得超过513个赞
知道大有可为答主
回答量:1570
采纳率:0%
帮助的人:1307万
展开全部
举个例子:
假设a表和b表的数据是这样的。
a b
id name  id stock 
1  a 1 15
2 b 2 50
3 c  

select * from a inner join b on a.id=b.id
这个语法是连接查询中的内连接,它产生的结果是
两个表相匹配的记录出现在结果列表中。
根据上面的表,出现的结果是这样的
a.id name b.id stock
1   a 1 15
2 b 2 50
----------------------------
select * from a,b where a.id=b.id
这个语法是内连接的另外一种写法,其执行结果与inner join 一样

--------------------------------

select * from a left/right join b on a.id=b.id
这个是外连接语法中的左外连接或右外连接
如果是左外连接的话,它将显示a表的所有记录,
select a.*,b.* from a left join b on a.id=b.id
查询的结果是这样的:
a.id name b.id stock
1   a 1 15
2 b 2 50
3 c null null 
--------------------------------------------
如果是右外连接的话,它将显示b表的所有记录,
select a.*,b.* from a right join b on a.id=b.id
查询的结果是这样的:
a.id name b.id stock
1   a 1 15
2 b 2 50
zzhd7
2011-12-08 · 超过13用户采纳过TA的回答
知道答主
回答量:66
采纳率:0%
帮助的人:37.7万
展开全部
简单点说 inner join 就是 只把连接的表中的数据符合链接条件的显示出来
leftjion 是上面的基础上 把左边的表上不符合链接条件的数据显示出来
rightjion 是在innerjoin的基础上把右边表的不符合条件的数据显示出来
还有个fulljoin 把两边所有的数据都列出来
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
a2835131
2011-12-12 · 超过26用户采纳过TA的回答
知道答主
回答量:76
采纳率:0%
帮助的人:57.8万
展开全部
孰能生巧 自己多试着多在数据库中实际运用就知道了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
头掣章ce4a6
2011-12-08 · 超过11用户采纳过TA的回答
知道答主
回答量:61
采纳率:0%
帮助的人:33.7万
展开全部
楼上正解
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式