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

高分求个SQL,这个用Group by该怎么弄呀?

楼主phckt(泡壶茶)2006-03-15 20:49:08 在 MS-SQL Server / 基础类 提问

表1      
  id     filename     pid      
  1         aa                             3      
  2         aa                             2      
  3         bb                             1      
  表2      
  id     filename      
  1         bb      
  2         aa      
  3         aa          
  4         aa      
     
  现在要查出表2中     id=pid的项目该如何写SQL      
  如这样的结果,注意排序是按表1的id      
  id         filename      
  1             aa      
  2             bb 问题点数:100、回复次数:9Top

1 楼zjcxc(邹建)回复于 2006-03-15 20:55:50 得分 20

select   b.*  
  from   ta,   a,   tb   b  
  whee   b.id=a.pid  
  order   by   a.idTop

2 楼scmail81(琳·风の狼(修罗))回复于 2006-03-15 20:56:37 得分 15

!!??  
   
  select     表2.filename      
  from    
        表1,表2  
  where    
        表1.pid=表2.id  
  order   by   表1.idTop

3 楼xeqtr1982(Visual C# .NET)回复于 2006-03-15 20:58:17 得分 5

同意老大.可是楼主给的结果不知道怎么查询出来Top

4 楼wangtiecheng(不知不为过,不学就是错!)回复于 2006-03-15 21:07:50 得分 20

 
  create   table   #t1(id   int,filename   varchar(100),   pid   int)  
  create   table   #t2(id   int,filename   varchar(100))  
   
  insert   into   #t1(id,filename,pid)  
  select   1,'aa',3   union   all    
  select   2,'aa',2   union   all    
  select   3,'bb',1  
   
  insert   into   #t2(id,filename)  
  select   1,'bb'   union   all  
  select   2,'aa'   union   all  
  select   3,'aa'   union   all  
  select   4,'aa'  
   
  select   *   from   #t1   select   *   from   #t2  
   
  select   b.*   from   #t1   a   inner   join   #t2   b   on   a.pid=b.id   order   by   a.id  
   
  drop   table   #t1,#t2  
  Top

5 楼phckt(泡壶茶)回复于 2006-03-15 21:39:55 得分 0

用zjcxc(邹建)  
  select   b.*  
  from   ta,   a,   tb   b  
  whee   b.id=a.pid  
  order   by   a.id  
   
  的方法查询出来的结果是  
  id     filename      
  3         aa    
  2         aa      
  1         bb  
  可能我没说清楚吧,   最终是要按filename   group   by的,不过表2还有很多其它项目要输出,一直找不到一个好的方法.  
   
           
   
   
  Top

6 楼zjdyzwx(十一月猪)回复于 2006-03-16 08:23:35 得分 20

 
  DECLARE   @T1   TABLE(ID   INT   ,   FILENAME   VARCHAR(2),   PID   INT)  
  DECLARE   @T2   TABLE(ID   INT   ,   FILENAME   VARCHAR(2))  
   
  INSERT   INTO   @T1  
  SELECT   1,         'aa',                             3     UNION   ALL    
  SELECT   2,         'aa',                             2     UNION   ALL    
  SELECT   3,         'bb',                             1  
   
   
  INSERT   INTO   @T2  
  SELECT   1,         'bb'   UNION   ALL      
  SELECT   2,         'aa'   UNION   ALL  
  SELECT   3,         'aa'   UNION   ALL        
  SELECT   4,         'aa'    
   
   
  SELECT   MIN(A.ID)   AS   ID   ,A.FILENAME   FROM   @T1   AS   A  
  INNER   JOIN   @T2   AS   B   ON   A.PID   =   B.ID    
  GROUP   BY   A.FILENAMETop

7 楼phckt(泡壶茶)回复于 2006-03-16 13:24:05 得分 0

谢谢大家,用了个笨办法,终于解决了分组和排序的问题.分有点多,   来者有份.Top

8 楼Oliko(实习菜)回复于 2006-03-16 14:19:44 得分 20

--楼主数据没有说明清楚呢,结果中的2怎么会对应bb?是重新生成的ID?  
  create   table   #t1(Fid   int,Fname   varchar(20),Pid   int)  
  insert   into   #T1   values(1,'aa',3)  
  insert   into   #T1   values(2,'aa',2)  
  insert   into   #T1   values(3,'bb',1)  
  create   table   #t2(Fid   int,Fname   varchar(20)   )  
  insert   into   #T2   values(1,'bb')  
  insert   into   #T2   values(2,'aa')  
  insert   into   #T2   values(3,'aa')  
  insert   into   #T2   values(4,'aa')  
   
   
   
    create   table   #T3   (   Fid   int   IDENTITY(1,1),Fname   varchar(20))  
   
  insert   into   #t3   (Fname)   select   distinct   Fname   from   #t1   a   where   a.Pid   in   (select   Fid   from   #t2)      
   
  select   *   from   #t3  
  drop   table   #t1  
  drop   table   #t2  
  drop   table   #t3  
  Top

9 楼Oliko(实习菜)回复于 2006-03-16 14:22:45 得分 0

忘了把执行结果贴出来,补上  
  第一个表数据  
  Fid                   Fname                                 Pid                    
  -----------   --------------------   -----------    
  1                       aa                                       3  
  2                       aa                                       2  
  3                       bb                                       1  
   
  第二个表数据  
   
  Fid                   Fname                                  
  -----------   --------------------    
  1                       bb  
  2                       aa  
  3                       aa  
  4                       aa  
   
  结果:  
  Fid                   Fname                                  
  -----------   --------------------    
  1                       aa  
  2                       bb  
   
  Top

相关问题

  • SQL语句 Group by
  • sql语句 的group by
  • 高分求sql
  • 高分求sql
  • 高分求SQL
  • sql 抢分题
  • 这个分组的SQL语句怎么弄?
  • datatable或者dataview里面怎么写group by这个sql语句呀,100分散
  • 30分 sql问题
  • 100分求sql书?

关键词

  • aa
  • fid
  • fname
  • pid
  • allselect
  • bb
  • filename
  • 表
  • union
  • insert

得分解答快速导航

  • 帖主:phckt
  • zjcxc
  • scmail81
  • xeqtr1982
  • wangtiecheng
  • zjdyzwx
  • Oliko

相关链接

  • SQL Server类图书

广告也精彩

反馈

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