如何按名称查找不匹配的第n个子行?

问题描述 投票:0回答:1

我正在尝试编写一个查询来查找第n个子记录,只有第n个子记录名称不匹配。

简化的数据结构:

  • 根(PK:id) Job(PK:id,FK:idRoot - > Root.id) 任务(PK:id,FK:idParent - > Job.id,FK:idRoot - > Root.id)

所有ID字段都是字符串(我受当前设计的支配,不是我们要改变的)

这个想法是,子查询每个根只能获得一个匹配,并且将根据来自其他根的另一个匹配来评估这些匹配。除非子查询的所有结果都匹配(在指定的行上),否则它们都会失败。基本上我需要所有第n个任务在所有选定的根中具有相同的名称,否则它们都会失败。

我有一个查询,它给我每个根的每个第n个子记录(其中Task是子表)。但是,我无法弄清楚如何检查平等。此外,这需要适用于SQL Compact和SQL Server,这限制了某些功能。

这是n = 1(第一个任务)

SELECT COUNT(r.id) as RowIndex, t.id, t.idRoot, t.Name
FROM Task t
  INNER JOIN Job j ON j.id = t.idParent
  INNER JOIN (
    SELECT b.id, b.idParent, b.idRoot, b.StartDate
    FROM Task b
      INNER JOIN Job c ON b.idParent = c.idRec
  ) r ON t.StartDate >= r.StartDate
      AND r.idParent = j.id 
      AND t.idRoot = r.idRoot
WHERE t.idRoot IN ('1', '2', '3', '4')
  AND j.Type LIKE '%Example%'
GROUP BY t.idRoot, t.id, t.Name
HAVING COUNT(r.id) = 1    

这给了我一些类似的东西:

╔══════════╦════╦════════╦════════════╗
║ RowIndex ║ ID ║ IDRoot ║    Name    ║
╠══════════╬════╬════════╬════════════╣
║        1 ║  4 ║      2 ║ 1st Task   ║
║        1 ║  7 ║      3 ║ 1st Task   ║
║        1 ║ 11 ║      4 ║ First Task ║
╚══════════╩════╩════════╩════════════╝

因此,在上面的结果中,我正确地从“示例”作业类型中返回第一个任务。我无法弄清楚如何在名字不匹配的情况下获得结果。如果每个名称都是“第一个任务”,则查询应该返回任何内容。

更新:

Here's a link到pastebin,可以创建表并加载样本数据。

查询A返回作业类型A的第一个任务,结果显示任务名称不匹配。因此,我希望返回这两个任务ID。

查询B返回作业类型B的第一个任务,结果显示所有任务名称匹配。因此,我希望不返回任何这些任务ID。

sql sql-server sql-server-ce
1个回答
0
投票

尝试使用以下查询:

SELECT
    r.id
FROM root r
INNER JOIN job j
ON j.idRoot = r.id
INNER JOIN task t
ON t.idParent = j.id 
    AND t.idRoot = r.id
GROUP BY r.id
HAVING MIN(t.name) <> MAX(t.name)

基本上,我们排列所有连接,按所有名称应该相同的值排列,然后确认最小名称与最大名称相同。如果这样做/不起作用,请告诉我。