首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >复杂的mysql选择查询6

复杂的mysql选择查询6
EN

Stack Overflow用户
提问于 2013-09-21 05:36:53
回答 2查看 40关注 0票数 0

我有一个包含2列的表: w_id(word id)和txt_id(text id)

例如,我有以下值:

代码语言:javascript
复制
-----------------
| 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个文本中是两次:

代码语言:javascript
复制
  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
EN

回答 2

Stack Overflow用户

发布于 2013-09-21 05:39:54

代码语言:javascript
复制
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

  • SQLFiddle Demo

您也可以使用LEFT JOIN完成此操作,

代码语言:javascript
复制
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

  • SQLFiddle Demo
票数 3
EN

Stack Overflow用户

发布于 2013-09-21 05:43:31

你能给我更多的细节吗?

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

还有:

我想如果我们用

代码语言:javascript
复制
SELECT DISTINCT w_id
FROM your_table_name
WHERE txt_id = 7

结果将是150 151 152

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18926257

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档