我有一个包含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发布于 2013-09-21 05:39:54
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-21 05:43:31
你能给我更多的细节吗?
根据您的问题,我可能会得到与bfavaretto相同的SQL。
还有:
我想如果我们用
SELECT DISTINCT w_id
FROM your_table_name
WHERE txt_id = 7结果将是150 151 152
https://stackoverflow.com/questions/18926257
复制相似问题