0

我有 2 列的表:w_id(word id) 和 txt_id(text id)

例如我有这个值:

-----------------
| w_id  | txt_id |
-----------------
| 150  |   7    |
-----------------
| 151  |   7    |
-----------------
| 152  |   7    |
-----------------
| 152  |   7    |
-----------------
| 151  |   8    |
-----------------
| 160  |   8    |
-----------------
| 165  |   8    |
-----------------

我想获取 w_id 列表,如果我想获取文本 7 的单词,则仅在此表的特定文本中,它将是 150 和 152。

我需要你的帮助来编写这个查询。我现在仍在考虑自己解决这个问题。这张桌子可以很大。数百万行。所以我需要仔细地写

我试试这个,但这是错误的:这个查询只给我 150,而不是 152。因为它在 7 个文本中是两次:

  SELECT w_id
  FROM tablename
  WHERE w_id
  IN (
    SELECT w_id
    FROM tablename
    WHERE txt_id =  '7'
    GROUP BY w_id
  )
  GROUP BY w_id
  HAVING COUNT(w_id) = 1
4

2 回答 2

3
SELECT  w_id
FROM    tableName a
WHERE   txt_id = 7 AND
        NOT EXISTS
        (
            SELECT  1
            FROM    tableName b
            WHERE   a.w_id = b.w_id AND
                    txt_id <> 7
        )
GROUP   BY w_id

您也可以使用LEFT JOIN,

SELECT  a.w_id
FROM    tableName a
        LEFT JOIN tableName b
            ON a.w_id = b.w_id AND
                b.txt_id <> 7
WHERE   b.w_id IS  NULL
GROUP   BY a.w_id
于 2013-09-20T21:39:54.313 回答
-1

你能提供更多细节吗?

根据您的问题,我可能会得到与 bfavaretto 相同的 SQL。

并且:

我想如果我们使用

SELECT DISTINCT w_id
FROM your_table_name
WHERE txt_id = 7

结果将是 150 151 152

于 2013-09-20T21:43:31.343 回答