我正在尝试编写一个查询,显示我们的唯一用户、他们在系统中第一次记录条目的日期以及他们最后一次记录条目的日期。它们分为两个表:用户表和日志表。
用户:
| 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。我希望得到一些帮助。