问一下超难的问题
首先先宣传一下自已的技术站
www.studysea.net
感兴趣的朋友进去看看啊
test1表
字段:aa,bb,cc
test2表
字段:aa,dd
从两个表中选出aa,bb,cc,dd字段,其中如果test1.aa能和test2.aa关联上,则dd为test2.dd,如果关联不上,则为空
我写的sql 语句
select test1.aa,bb,cc,dd from test1,test2 where test1.aa=test2.aa
这句只能实现,如果关联上test1.aa=test2.aa则显示记录,而其他的test1中的记录则被删选掉了,请问应如果写sql语句,才能实现上面的功能
问题点数:100、回复次数:21Top
1 楼wl3721()回复于 2004-08-03 20:42:59 得分 40
select test1.aa,bb,cc,dd from test1,test2 where test1.aa(+)=test2.aaTop
2 楼csdnfuns(不明白)回复于 2004-08-03 20:56:18 得分 30
用外连接,‘(+)’既可以放在等号左边也可以放在等号右边,但一定要放在缺少相应信息的那一边。Top
3 楼ineedtostudy(amei)回复于 2004-08-03 21:03:44 得分 5
同意楼上Top
4 楼dinya2003(OK)回复于 2004-08-04 09:12:13 得分 5
select
a.aa,
a.bb,
a.cc,
b.dd
from
test1 a,
test2 b
where
a.aa=b.aa(+)
--你的网站要积分多少才能下载电影啊?Top
5 楼bzszp(SongZip)回复于 2004-08-04 09:42:26 得分 5
一楼的正好写反了
select test1.aa,bb,cc,dd from test1,test2 where test1.aa=test2.aa(+);Top
6 楼yubing8(yubing8)回复于 2004-08-04 10:26:47 得分 0
电影下载暂时关闭了,过段时间再开放
Top
7 楼yubing8(yubing8)回复于 2004-08-04 10:28:00 得分 0
另外,再问一下(+)是什么意思,好像标准的sql 里没有啊,sql server2000里,该怎么写Top
8 楼bzszp(SongZip)回复于 2004-08-04 10:29:02 得分 5
select test1.aa,bb,cc,dd from test1 left join test2
on test1.aa=test2.aaTop
9 楼bzszp(SongZip)回复于 2004-08-04 10:30:50 得分 5
(+)表示外连接Top
10 楼jackjingsg(飞翔的精灵)回复于 2004-08-04 10:44:21 得分 5
select test1.aa,bb,cc,dd from test1,test2 where test1.aa=test2.aa(+);
--这样就把test1中所有的记录取出来了Top
11 楼bzszp(SongZip)回复于 2004-08-04 10:52:13 得分 0
是的Top
12 楼Guohui(rex)回复于 2004-08-04 11:57:47 得分 0
如果你是用oracle 9i,那你可以使用和m$sqlserver一样的inner join ,right join ,left join,如果不是9i,那只好用(+)来表示左右联接了Top
13 楼armyyd(不会游泳的猫)回复于 2004-08-04 18:33:29 得分 0
唉,没时间看
楼上的都说完了,我没什么要说的了,顶一哈子Top
14 楼csdnfuns(不明白)回复于 2004-08-04 22:24:23 得分 0
wl3721:好像写反了Top
15 楼yubing8(yubing8)回复于 2004-08-05 10:49:55 得分 0
csdn高手真多,推荐几本数据库的好书吧,小弟受教了,谢谢大家Top
16 楼yubing8(yubing8)回复于 2004-08-06 09:49:52 得分 0
upTop
17 楼guxiaobo1982(Amber)回复于 2004-08-06 17:05:08 得分 0
垃圾东西,还什么技术网站,Top
18 楼yubing8(yubing8)回复于 2004-08-07 18:27:33 得分 0
upTop
19 楼xhy818(zh1860)回复于 2004-08-08 16:42:33 得分 0
select test1.aa,bb,cc,dd from test1,test2 where test1.aa=test2.aa(+)
或
select * from test1 left join test2 on test1.aa=test2.aa
Top
20 楼liuyi8903(不让疑问伴随)回复于 2004-08-08 18:15:27 得分 0
都搞定了.我也给你顶顶好了.Top
21 楼yubing8(yubing8)回复于 2004-08-09 17:43:29 得分 0
结帖了,感谢大家的帮助Top




