首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL计数意外结果

MySQL计数意外结果
EN

Stack Overflow用户
提问于 2012-09-01 11:11:02
回答 1查看 281关注 0票数 1

我的数据库结构如下所示:

https://docs.google.com/open?id=0B9ExyO6ktYcOenZ1WlBwdlY2R3c

对一些表格的解释:

  1. answer_chk_results -检查答案表.所以如果这个表上不存在某些答案,那就意味着它没有被检查
  2. lesson_questions -课程<->问题关联(按id)表

当我像这样查询数据库时:

代码语言:javascript
复制
SELECT
    q.id,
    q.content,
    q.type
FROM
    `questions_and_exercises` q,
    `lesson_questions` lq
WHERE
    q.id = lq.qid
AND lq.lid = 1

我收到了所有的问题清单。但我想要的是每一个问题的答案和核对答案。当我使用这个查询时:

代码语言:javascript
复制
SELECT
    q.id,
    q.content,
    q.type,
    COUNT(DISTINCT a.ID) answer_count,
    COUNT(DISTINCT acr.id) checked_count
FROM
    `questions_and_exercises` q,
    `lesson_questions` lq
LEFT JOIN answers a ON a.qid = lq.qid,
LEFT JOIN `answer_chk_results` acr ON acr.aid = a.id
WHERE
    q.id = lq.qid
AND lq.lid = 1

结果只是一个问题和错误的答案数。(我的数据库里大约有9-10个问题)我漏掉了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-01 11:15:21

一个group by会有帮助,比如:

代码语言:javascript
复制
select  q.id
,       q.content
,       q.type
,       count(distinct a.id) as answer_count
,       count(acr.checked) as checked_count
from    questions_and_exercises q
join    lesson_questions lq
on      q.id = lq.id
left join
        answers a 
on      a.qid = lq.qid
left join
        answer_chk_results acr 
on      acr.aid = a.id
group by
        q.id
,       q.content
,       q.type

注意,count(acr.checked)返回answer_chk_results表中有一行的答案数。count(distinct acr.checked)返回检查列的不同值的数目。如果选中为布尔值,则始终为1或0。

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

https://stackoverflow.com/questions/12227216

复制
相关文章

相似问题

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