将多个查询的结果合并为一个table
Combine the results of multiple queries into one table
我有一个 table,它通过 MS Access 2013 中的表单填充其条目。我在下面附上了 table 的一部分的图像。使用 StartTime 条目,我创建了一个查询来显示在上午 8 点到 9 点之间发生的所有事务,并创建了另一个查询来显示在上午 9 点到 10 点之间发生的所有事务,依此类推。问题是我有很多疑问。有没有一种方法可以将所有查询中的语句组合成一个 sql 语句,并将结果输出到一个数据表中,列标题为“8AM-9AM”、“9AM-10AM”、“10AM-11AM”等.谢谢。
查询示例:
SELECT TimeValue([StartTime])
FROM Table1
WHERE (TimeValue([StartTime]) Between '8:00:00 AM' And '8:59:59 AM')
以下是我所做的,可能会对您有所帮助,或者至少让您入门。我为您想要输出的每个小时(8-9、9-10、10-11 等)创建了查询。然后我创建了一个最终查询,它对所有查询使用 UNION
。
您可能已经有的查询示例:
SELECT TIMEVALUE(T1.StartTime)
FROM Table1 AS T1
WHERE (TIMEVALUE(T1.StartTime) Between '8:00:00 AM' And '8:59:59 AM');
第二个:
SELECT TIMEVALUE(T1.StartTime)
FROM Table1 AS T1
WHERE (TIMEVALUE(T1.StartTime) Between '9:00:00 AM' And '9:59:59 AM');
等等...
最终查询示例:
SELECT '' AS [8-9],'' AS [9-10],'' AS [10-11]
FROM [8-9AM]
UNION
SELECT T1.*,'',''
FROM [8-9AM] AS T1
UNION
SELECT '',T2.*,''
FROM [9-10AM] AS T2
UNION ALL SELECT '','',T3.*
FROM [10-11AM] AS T3
(and so on...);
注意:我必须创建一个空白的第一行,以便它在我的机器上正确命名该列。不确定你是否会遇到同样的问题。
编辑: 可能是一种更简单的方法,只使用一个 table:
SELECT ID,
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '8:00:00 AM' And '8:59:59 AM',
TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '8:00:00 AM' And '8:59:59 AM', ''
) AS [8-9],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '9:00:00 AM' And '9:59:59 AM', TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '9:00:00 AM' And '9:59:59 AM', ''
) AS [9-10],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '10:00:00 AM' And '10:59:59 AM',
TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '10:00:00 AM' And '10:59:59 AM', ''
) AS [10-11],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '11:00:00 AM' And '11:59:59 AM', TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '11:00:00 AM' And '11:59:59 AM', ''
) AS [11-12],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '12:00:00 AM' And '12:59:59 AM',
TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '12:00:00 AM' And '12:59:59 AM', ''
) AS [12-1],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '1:00:00 AM' And '1:59:59 AM', TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '1:00:00 AM' And '1:59:59 AM', ''
) AS [1-2]
FROM Table1 AS T1
我有一个 table,它通过 MS Access 2013 中的表单填充其条目。我在下面附上了 table 的一部分的图像。使用 StartTime 条目,我创建了一个查询来显示在上午 8 点到 9 点之间发生的所有事务,并创建了另一个查询来显示在上午 9 点到 10 点之间发生的所有事务,依此类推。问题是我有很多疑问。有没有一种方法可以将所有查询中的语句组合成一个 sql 语句,并将结果输出到一个数据表中,列标题为“8AM-9AM”、“9AM-10AM”、“10AM-11AM”等.谢谢。
查询示例:
SELECT TimeValue([StartTime])
FROM Table1
WHERE (TimeValue([StartTime]) Between '8:00:00 AM' And '8:59:59 AM')
以下是我所做的,可能会对您有所帮助,或者至少让您入门。我为您想要输出的每个小时(8-9、9-10、10-11 等)创建了查询。然后我创建了一个最终查询,它对所有查询使用 UNION
。
您可能已经有的查询示例:
SELECT TIMEVALUE(T1.StartTime)
FROM Table1 AS T1
WHERE (TIMEVALUE(T1.StartTime) Between '8:00:00 AM' And '8:59:59 AM');
第二个:
SELECT TIMEVALUE(T1.StartTime)
FROM Table1 AS T1
WHERE (TIMEVALUE(T1.StartTime) Between '9:00:00 AM' And '9:59:59 AM');
等等...
最终查询示例:
SELECT '' AS [8-9],'' AS [9-10],'' AS [10-11]
FROM [8-9AM]
UNION
SELECT T1.*,'',''
FROM [8-9AM] AS T1
UNION
SELECT '',T2.*,''
FROM [9-10AM] AS T2
UNION ALL SELECT '','',T3.*
FROM [10-11AM] AS T3
(and so on...);
注意:我必须创建一个空白的第一行,以便它在我的机器上正确命名该列。不确定你是否会遇到同样的问题。
编辑: 可能是一种更简单的方法,只使用一个 table:
SELECT ID,
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '8:00:00 AM' And '8:59:59 AM',
TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '8:00:00 AM' And '8:59:59 AM', ''
) AS [8-9],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '9:00:00 AM' And '9:59:59 AM', TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '9:00:00 AM' And '9:59:59 AM', ''
) AS [9-10],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '10:00:00 AM' And '10:59:59 AM',
TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '10:00:00 AM' And '10:59:59 AM', ''
) AS [10-11],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '11:00:00 AM' And '11:59:59 AM', TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '11:00:00 AM' And '11:59:59 AM', ''
) AS [11-12],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '12:00:00 AM' And '12:59:59 AM',
TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '12:00:00 AM' And '12:59:59 AM', ''
) AS [12-1],
SWITCH(
TIMEVALUE(T1.StartTime) BETWEEN '1:00:00 AM' And '1:59:59 AM', TIMEVALUE(T1.StartTime)
,TIMEVALUE(T1.StartTime) NOT BETWEEN '1:00:00 AM' And '1:59:59 AM', ''
) AS [1-2]
FROM Table1 AS T1