5

我有一个看起来像这样的表:

| CODE   |  LEVEL1  |  LEVEL2  |  LEVEL3  |   SEC_ID   |
| CODE1  |  LEV1    |  LEV2    |  LEV3    |   123456   |
| CODE2  |  LEV1    |  LEV2    |  LEV3    |   234561   |
| CODE2  |  LEV1    |  LEV2    |  Term    |   345612   |
| CODE3  |  LEV1    |  LEV2    |  LEV3    |   456123   |

我需要我的查询在列中查找单词“Term”,Level3然后排除具有相同CODE.

因此,在上面的示例中,查询将从结果中排除第 2 行和第 3 行。

如果不清楚,请告诉我。

4

1 回答 1

6

您可以使用NOT EXISTS排除任何具有level3相同值的记录code

select *
from yourtable t1
where not exists (select *
                  from yourtable t2
                  where level3 = 'Term'
                   and t1.code = t2.code)

请参阅带有演示的 SQL Fiddle

结果:

|  CODE | LEVEL1 | LEVEL2 | LEVEL3 | SEC_ID |
---------------------------------------------
| CODE1 |   LEV1 |   LEV2 |   LEV3 | 123456 |
| CODE3 |   LEV1 |   LEV2 |   LEV3 | 456123 |
于 2012-11-19T09:52:11.093 回答