首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >连接3个表以从调查中获取详细信息

连接3个表以从调查中获取详细信息
EN

Stack Overflow用户
提问于 2020-01-30 06:41:51
回答 1查看 51关注 0票数 0

我做了一个调查,他们有几个领域必须选择。例如:工作场所、工作经验和满意度。

代码语言:javascript
复制
tlDetail
SurveyId QuestionId ChoiceId 
1          1           1
1          2           5
1          3           7
2          1           3
2          2           6
2          3           8

tblquestion
QuestionId Question
1           Question 1
2           Question 2
3           Question 3

TblChoice
ChoiceId QuestionId ChoiceName
1          1          HR
2          1          Accountant
3          1          Teacher
4          2          >10 years
5          2          <10 years
6          2          =10 years
7          3          satisfies
8          3          not satisfied
9          3          no comment

我需要写一个查询,告诉我有多少教师是=10年并且满意的

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-01-30 06:47:01

您可以使用两个级别的聚合:

代码语言:javascript
复制
select count(*)
from (
    select 1 x
    from tlDetail d
    inner join tblChoice c 
        on  c.QuestionId  = d.QuestionId 
        and c.ChoiceId = d.ChoiceId
    group by survey_id
    having
        max(case when c.ChoiceName = 'Teacher' then 1 end) = 1
        and max(case when c.ChoiceName = '=10 years' then 1 end) = 1
) t

请注意,这假设两个不同的问题永远不会有相同的ChoiceName,这对于您的样本数据是可以的,但在现实世界中不一定是这样。如果您想要更准确的答案,那么您需要确定您希望哪个问题的答案是'Teacher'还是'=10 years',例如:

代码语言:javascript
复制
select count(*)
from (
    select 1 x
    from tlDetail d
    inner join tblChoice c 
        on  c.QuestionId  = d.QuestionId 
        and c.ChoiceId = d.ChoiceId
    inner join tblQuestion q 
        on  q.QuestionId = d.QuestionId
    group by survey_id
    having
        max(case 
            when q.Question = 'Question 1' and c.ChoiceName = 'Teacher' 
            then 1 
        end) = 1
        and max(case 
            when q.Question = 'Question 2' and c.ChoiceName = '=10 years' 
            then 1 
        end) = 1
) t
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59976674

复制
相关文章

相似问题

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