日期:2014-05-17  浏览次数:20572 次

一sql查询语句
 一张帖子表和一张回复表  查询出24小时内回复次数最多的前10条主题帖子
------最佳解决方案--------------------
引用:
我在加一点东西 
  
两张表的样子 你看一下
   
帖子表 回复表
  Tid RId
  Tcontent Tid(外键)
  TName CreatTime

一张帖子表和一张回复表 查询出24小时内回复次数最多的前10条主题帖子



select top 10 m.* , count(1) 回复次数 from 帖子表 m , 回复表 n where m.Tid = n.Tid and datediff(hh,n.CreatTime,getdate()) <= 24 order by 回复次数 desc

select top 10 m.* , count(1) 回复次数 from 帖子表 m , 回复表 n where m.Tid = n.Tid and datediff(dd,n.CreatTime,getdate()) <= 1 order by 回复次数 desc

------其他解决方案--------------------

select
  top 10 *
from
  (select id,count(1) as 发帖次数 from 帖子表 where datediff(hh,createtime,getdate())<24 group by id)a,
  (select id,count(1) as 回复次数 from 回复表 where datediff(hh,createtime,getdate())<24 group by id)b
where
   a.id=b.id
order by
   b.回复次数 desc

------其他解决方案--------------------

select
  top 10 a.tname
from
  帖子表 a,(select tid,count(1) as 回复次数 from 回复表 group by tid)b
where
  a.tid=b.tid
and
  datediff(hh,CreatTime,getdate())<=24
order by
  b.回复次数 desc

------其他解决方案--------------------
select
  top 10 a.tname
from
  帖子表 a,(select tid,count(1) as 回复次数 from 回复表 group by tid)b
where
  a.tid=b.tid
and
  datediff(hh,CreatTime,getdate())=24
order by
  b.回复次数 desc

------其他解决方案--------------------
select
  top 10 *
from
  (select id,count(1) as 发帖次数 from 帖子表 group by id)a,
  (select id,count(1) as 回复次数 from 回复表 group by id)b
where
   a.id=b.id
order by
   b.回复次数 desc

------其他解决方案--------------------
我在加一点东西 
  
两张表的样子 你看一下
     
帖子表          回复表
   Tid         RId
   Tcontent    Tid(外键)
   TName       CreatTime

 

------其他解决方案--------------------
表的结构我都看得不是很清楚,主表没有createtime?
我觉得在应在是主表的createtime与最后回复的时间小于24 记录最多的。
------其他解决方案--------------------
我也遇到这个问题,这是我参考楼上各位大侠写的,不知道有错没……