注册 登录
编程论坛 SQL Server论坛

问个sql面试题

CMYK 发布于 2013-07-09 15:25, 857 次点击
用sql查询出每人当天第一次登陆的记录
大家别笑,我憋了半天没憋出来,泪奔了,求助这咋写
6 回复
#2
yss07292013-07-09 22:28
select top 1 * from tb_login where datediff(day,logindate,getdate())=0 order by logindate asc
#3
CMYK2013-07-10 09:50
楼上的方法只能返回当天第一次登陆的那个人的记录,需求是当天只要有登陆的人的第一次登陆记录。



假设有tb_login 表,tb_login 有name和logindate,name为登陆者的名字, logindate为登陆的时间(每个用户登陆一次,记录一次),现在要做的是查询出当天有登陆记录的人的第一次登陆记录,这咋写
#4
yss07292013-07-12 14:58
lz可以试试这段
程序代码:

select * from tb_login where exists(
select top 1 name,logindate from tb_login where datediff(day,logindate,getdate())=0
group by name,logindate order by logindate asc )


子查询里面按照登录时间和登录人分组筛选出当天第一次登陆的信息
#5
volte2013-07-18 11:27
这个用临时表和游标解决起来方便,
单纯的搞SQL,费事,还不准确。
上面的SQL都正确吗????
#6
ap0303292013-07-23 15:56
用row_number()分组呗

select name ,logindate
from(
select name,logindate,row_number()over(partition by name order by logindate)as rowid
 from tb_login
where logindate= 当天
) as t
where rowid = 1
#7
libin19900622013-08-21 14:16
这个要视表而言  你最好把表结构告知
1