SQL联合查询中的关键语法

转自:http://www.cnblogs.com/aaapeng/archive/2010/01/20/1652151.html


联合查询效率较高.以下例子来说明联合查询的好处

t1表结构(用户名,密码)

userid {int}

username {varchar(20)}

password {varchar(20)}

1

jack

jackpwd

2

owen

owenpwd

t3表结构(用户积分,等级)

userid {int}

jf {int}

dj {int}

1

20

3

2

50

6

第一、内联(inner join)

如果想把用户信息,积分,等级都列出来.那么一般会这样写

select * from t1 ,t3 where t1.userid = t3.userid   其实这样的结果等同于select * from t1 inner join t3 on t1.userid=t3.userid

就是把两个表中都存在userid的行拼成一行.这是内联.但后者的效率会比前者高很多.建议用后者的写法.

运行结果:

userid

usernamepassworduseridjf

dj

1

jackjacjpwd1203

第二、左联(left outer join)显示左表中的所有行

select * from t1 left outer join t3 on t1.userid=t3.userid

运行结果:

userid

usernamepassworduseridjf

dj

1

jackjacjpwd1203
2owenowenpwdNULLNULLNULL

第三、右联(right outer join)显示右表中的所有行

select * from t1 right outer join t3 on t1.userid=t3.userid

运行结果:

userid

usernamepassworduseridjf

dj

1

jackjacjpwd1203
NULLNULLNULL3506

第四、全联(full outer join)显示两边表中所有行

select * from t1 full outer join t3 on t1.userid=t3.userid

运行结果:

userid

usernamepassworduseridjf

dj

1

jackjacjpwd1203
2owenowenpwdNULLNULLNULL
NULLNULLNULL3506

总结,关于联合查询,本人已测试过.效率的确比较高,4种联合方式如果可以灵活使用,基本上复杂的语句结构也会简单起来。

这4种方式是:Inner join、left outer join、right outer join、full outer join

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值