| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 857 人关注过本帖
标题:问个sql面试题
只看楼主 加入收藏
CMYK
Rank: 2
等 级:论坛游民
帖 子:67
专家分:74
注 册:2011-9-19
结帖率:46.15%
收藏
已结贴  问题点数:20 回复次数:6 
问个sql面试题
用sql查询出每人当天第一次登陆的记录
大家别笑,我憋了半天没憋出来,泪奔了,求助这咋写
搜索更多相关主题的帖子: 记录 
2013-07-09 15:25
yss0729
Rank: 3Rank: 3
来 自:江西 九江
等 级:论坛游侠
帖 子:43
专家分:197
注 册:2013-6-8
收藏
得分:20 
select top 1 * from tb_login where datediff(day,logindate,getdate())=0 order by logindate asc
2013-07-09 22:28
CMYK
Rank: 2
等 级:论坛游民
帖 子:67
专家分:74
注 册:2011-9-19
收藏
得分:0 
楼上的方法只能返回当天第一次登陆的那个人的记录,需求是当天只要有登陆的人的第一次登陆记录。



假设有tb_login 表,tb_login 有name和logindate,name为登陆者的名字, logindate为登陆的时间(每个用户登陆一次,记录一次),现在要做的是查询出当天有登陆记录的人的第一次登陆记录,这咋写
2013-07-10 09:50
yss0729
Rank: 3Rank: 3
来 自:江西 九江
等 级:论坛游侠
帖 子:43
专家分:197
注 册:2013-6-8
收藏
得分:0 
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 ) 


子查询里面按照登录时间和登录人分组筛选出当天第一次登陆的信息
2013-07-12 14:58
volte
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:69
帖 子:1167
专家分:1316
注 册:2004-12-19
收藏
得分:0 
这个用临时表和游标解决起来方便,
单纯的搞SQL,费事,还不准确。
上面的SQL都正确吗????

大家都是朋友,有空就来坐坐!
2013-07-18 11:27
ap030329
Rank: 1
等 级:新手上路
帖 子:4
专家分:5
注 册:2013-7-23
收藏
得分:0 
用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
2013-07-23 15:56
libin1990062
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-9-11
收藏
得分:0 
这个要视表而言  你最好把表结构告知
2013-08-21 14:16
快速回复:问个sql面试题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028897 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved