-2

我有 52 个是/否列参加每周 .. 我想查询以了解其中包含“是”或“否”的列数...有人可以帮我解决这个问题吗?如果您知道任何用于 Access 查询的推荐站点或社区,请告诉我。谢谢。

4

2 回答 2

1

我认为这是一个糟糕的设计。它打破了第一范式。

我可以设想一个用户表、一个会议表和一个多对多 JOIN 表,将用户与他们参加的会议联系起来。

查询所有会议会告诉您可以参加的日期。

使用 user_meeting JOIN 表加入用户表可以告诉您给定用户参加了哪些会议。

现在您有两组:所有可能的会议和给定用户参加的日期。如果你做了一个设定的差异,你会看到用户没有参加的潜在日期。

于 2012-11-07T15:06:32.253 回答
0

这是如何使用列表的粗略草图。毫无疑问,还有其他更好的方法,但这只是一个开始。

三周的差距:

SELECT b.UserID, b.WeekNo, (SELECT Top 1 WeekNo 
    FROM (SELECT * FROM table2 WHERE Attended=True) a 
    WHERE a.WeekNo > b.WeekNo) AS [next]
FROM (SELECT * FROM table2 WHERE Attended=True)  AS b
WHERE (((b.UserID)=1) AND (((SELECT Top 1 WeekNo 
    FROM (SELECT * FROM table2 WHERE Attended=True) a 
    WHERE a.WeekNo > b.WeekNo))>[b].[WeekNo]+3))
ORDER BY b.WeekNo;

出席人数:

SELECT Table2.UserID, Sum(Abs([Attended])) AS Attend
FROM Table2
GROUP BY Table2.UserID;

桌子:

UserID  WeekNo  Attended
1       1       True
1       2       True
1       3       True
1       4       True
1       5       False
1       6       False
1       7       True
1       8       True
1       9       False
1       10      False
1       11      False
1       12      True
1       13      True
1       14      True
于 2012-11-07T16:31:34.957 回答