我有两个表,第一个表包含一个数据提要(Data ),在检查点中输入数据,这些检查点被锁定在各种‘’上。这些巡逻与“ patrols ”(围绕同一路线进行多次巡逻)相联系。下面的SQL确保创建一个视图,只导致每次巡逻时只列出错过的检查点()。这很好,但是我需要包括检查点被时钟的原始表(数据导入表)中的时间。如何确保这一次包含在output视图中?要包含的原始表中的字段是出现日期,并驻留在数据导入表中
下面是我当前的SQL (工作):
CREATE VIEW MissedPoints AS
SELECT Routes.[Route id]
,[Data Import].[Patrol id]
,Routes.[Tag Name]
FROM Routes
INNER JOIN (SELECT DISTINCT [Route Id]
,[Patrol ID]
from [Data Import]) as [Data Import]
on [Data Import].[Route Id] = Routes.[Route Id]
EXCEPT
SELECT [Route Id]
,[Patrol ID]
,[Tag name]
FROM [Data Import]我似乎无法在正确的位置得到正确的SQL。
发布于 2014-07-15 10:13:15
我猜你实际上想要的是。这只会给出遗漏的检查点,假设错过的时间是NULL,如果不能,则可以将where条件更改为丢失的值,或者将我标记的两行添加到查询中的行放在相同的位置,以及except查询中的1行,以使字段再次匹配(但是丢失了where子句)。
CREATE VIEW MissedPoints AS
SELECT Routes.[Route id]
,[Data Import].[Patrol id]
,Routes.[Tag Name]
,[Data Import].[Occurrence Date] --Added
FROM Routes
LEFT JOIN (SELECT DISTINCT [Route Id]
,[Patrol ID]
,[Occurrence Date] --Added
from [Data Import]) as [Data Import]
on [Data Import].[Route Id] = Routes.[Route Id]
WHERE [Data Import].[Occurrence Date] is NULLhttps://stackoverflow.com/questions/24754769
复制相似问题