CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
IBM Rational 系统开发最佳实践工具包 WebSphere MQ 最佳实践 TOP 15
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  基础类

初来乍到,送高分求一语句!!

楼主cimzzxing()2006-03-06 12:24:16 在 MS-SQL Server / 基础类 提问

两个表A     B  
  table     A{  
      sfzh   varchar18  
      xm       varchar   10  
      csrq   varchar   8  
      jg       varchar   10  
      flag   int    
      }  
  table     B{  
      SFZH   varchar18  
      XM     varchar   10  
      CSRQ   varchar   8  
      JG       varchar   10    
      }  
      A表中数据量1000余条,B表中数据量二百万条。  
  要求:  
  1、如果A.sfzh和B.SFZH都非空,将满足A.sfzh=b.SFZH的行找出来,同时将A中检索过的行中A.flag设置为1。  
  2、如果A.sfzh   和   B.SFZH   有一个为空,将满足A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG的行找出来,同时将A中检索过的行中A.flag设置为1。  
  请问如何高效构造此语句。  
   
   
   
  问题点数:80、回复次数:6Top

1 楼zjcxc(邹建)回复于 2006-03-06 12:42:34 得分 0

--   找出满足条件的数据  
  select   A.*  
  from   A,   B  
  WHERE   (ISNULL(A.sfzh,'')   <>   ''   and   isnull(B.SFZH,'')   <>   ''   and   A.sfzh=b.SFZH)  
      or     ((ISNULL(A.sfzh,'')   =   ''   or   isnull(B.SFZH,'')   =   '')   and   (A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG))  
   
  --   设置标志  
  update   a   set   flag=1  
  from   A,   B  
  WHERE   (ISNULL(A.sfzh,'')   <>   ''   and   isnull(B.SFZH,'')   <>   ''   and   A.sfzh=b.SFZH)  
      or     ((ISNULL(A.sfzh,'')   =   ''   or   isnull(B.SFZH,'')   =   '')   and   (A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG))  
  Top

2 楼cimzzxing()回复于 2006-03-06 13:01:38 得分 0

就是先联接后,再判断吗,谢谢邹老大了!  
  这种方法高效吗?各位还有什么好的方法?Top

3 楼cimzzxing()回复于 2006-03-06 19:34:14 得分 0

我试了一下,两个表个联结生成的表好大阿  
  能不能这样做?  
  类似于:select   *   from   A   where   exists(   select   *   from   B   where   A.sfzh=B.SFZH)  
  就是先在A表中取一行,然后去和B表中的行去比,如果B表中SFZH不为空,则找出A.sfzh=B.SFZH的行,如果SFZH为空,则找出满足A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG的行。  
  不知道,这样怎么在一条语句中实现?Top

4 楼zjcxc(邹建)回复于 2006-03-06 19:36:47 得分 80

--   找出满足条件的数据  
  select   A.*  
  from   A  
  WHERE   exists(  
        select   *   from   B  
        where   ISNULL(A.sfzh,'')   <>   ''   and   isnull(B.SFZH,'')   <>   ''   and   A.sfzh=b.SFZH)  
              or     ((ISNULL(A.sfzh,'')   =   ''   or   isnull(B.SFZH,'')   =   '')   and   (A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG)))  
   
  --   设置标志  
  update   a   set   flag=1  
  select   A.*  
  from   A  
  WHERE   exists(  
        select   *   from   B  
        where   ISNULL(A.sfzh,'')   <>   ''   and   isnull(B.SFZH,'')   <>   ''   and   A.sfzh=b.SFZH)  
              or     ((ISNULL(A.sfzh,'')   =   ''   or   isnull(B.SFZH,'')   =   '')   and   (A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG)))  
  Top

5 楼cimzzxing()回复于 2006-03-06 20:13:11 得分 0

原来是这样啊,谢谢老大了!Top

6 楼cimzzxing()回复于 2006-03-06 21:15:21 得分 0

邹老大,又有新的问题了?  
      select   A.*  
  from   A  
  WHERE   exists(  
        select   *   from   B  
        where   ISNULL(A.sfzh,'')   <>   ''   and   isnull(B.SFZH,'')   <>   ''   and   A.sfzh=b.SFZH)  
              or     ((ISNULL(A.sfzh,'')   =   ''   or   isnull(B.SFZH,'')   =   '')   and   (A.xm=B.XM     and   A.csrq=B.CSRQ   and   A.jg=B.JG)))  
   
   
  如何把B.SFZH也同时select出来,还有在这两张表中,如何建立索引能够提高速度?Top

相关问题

  • 初来乍到,送50分
  • 初来乍到,送分!
  • 初来乍到,菜鸟送分!
  • 初来乍到,如何学好perl+送分+交个朋友
  • 初来乍到,散分!
  • 初来乍到,散分
  • 初来乍到,放分100
  • 圣诞放分啊!初来乍到!
  • 初来乍到,为谴责解决了问题不给分的恶习,本鸟30分相送。
  • 初来乍到,寻求DELPHI编程经验,200分全部送上!!大家赏脸,谢谢!!

关键词

  • 语句
  • 数据
  • sfzh
  • csrq
  • jg
  • xm
  • isnull
  • 表
  • varchar
  • 表中

得分解答快速导航

  • 帖主:cimzzxing
  • zjcxc

相关链接

  • SQL Server类图书

广告也精彩

反馈

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