我试图写展示我们独特的用户查询,在该系统首次记录条目的日期和他们的最后记录条目的日期。这些分为两个表:用户表和日志表。查询返回的用户,第一个记录和最后一个记录
用户:
| Userid | Username |
|--------|-------------|
|20 | Tom Smith |
|21 | Jim Jones |
|22 | Sandy Brown |
登录:
| Logid | UserID | Date | Value |
--------|---------|------------|--------------|
| 1 | 21 | 01/03/2013 | Login |
| 2 | 22 | 01/04/2013 | Login |
| 3 | 21 | 01/05/2013 | Edit |
| 4 | 20 | 01/06/2013 | Login |
| 5 | 20 | 01/07/2013 | Search |
| 6 | 22 | 01/08/2013 | Login |
| 7 | 21 | 01/09/2013 | Close |
| 8 | 21 | 01/11/2013 | Login |
| 9 | 20 | 01/12/2013 | Edit |
| 10 | 22 | 01/13/2013 | Search |
这是查询所期望的结果,我试图写:
|Userid | UserName | First Log Date | Last Log Date |
|-------|-------------|----------------|---------------|
| 20 | Tom Smith | 01/06/2013 | 01/12/2013 |
| 21 | Jim Jones | 01/03/2013 | 01/11/2013 |
| 22 | Sandy Brown | 01/04/2013 | 01/13/2013 |
到目前为止,我有前两个列,但是我无法弄清楚第一个和最后一个日期列,下面是我的查询到目前为止:
select
distinct(u.userid1) as 'Userid',
u.username as 'UserName'
from
users u,
log l
where
u.userid = l.userid
我正在使用SQL Server 2008.我想要一些帮助。
完美的答案。非常感谢。 –
不需要与群组区分,但它仍然有效。 – gmm
@gmm - 是的,你说的对,我的部分已经过时了 – LittleBobbyTables