CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
可用分押宝游戏火热进行中... 专题改版:Java Web 专题
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  Oracle >  开发

问一下超难的问题

楼主yubing8(yubing8)2004-08-03 20:33:04 在 Oracle / 开发 提问

首先先宣传一下自已的技术站  
  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

相关问题

  • 超级疑难问题,请大家进来研究一下
  • 超级疑难问题,请大家进来研究一下
  • 超级疑难问题,请大家进来研究一下
  • ========高手进来挑战一下超难的问题。。。。
  • 超难问题,大家发表一下意见,来者有分!(关于ldap的)
  • 超难问题,那位大虾给解释一下:windows2000起动时disk err
  • 请问一下AMD 2500+如何超频?
  • 超难问题,能不能让系统每一个小时关闭一下屏保
  • 超难问题~~~~~~~~~~~~~:(
  • 超难问题

关键词

  • aa
  • dd
  • test
  • bb
  • cc
  • 关联
  • join
  • 放在
  • where
  • left

得分解答快速导航

  • 帖主:yubing8
  • wl3721
  • csdnfuns
  • ineedtostudy
  • dinya2003
  • bzszp
  • bzszp
  • bzszp
  • jackjingsg

相关链接

  • Oracle类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo