首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否可以将此查询转换为连接?

是否可以将此查询转换为连接?
EN

Stack Overflow用户
提问于 2012-06-01 20:29:46
回答 2查看 57关注 0票数 2

以下是查询:

代码语言:javascript
复制
SELECT *
FROM square_achievements_achievements
JOIN square_achievements_achievement_counters ON square_achievements_achievement_counters.SAA_ID = square_achievements_achievements.SAA_ID
JOIN square_achievements_counters ON square_achievements_counters.SAC_ID = square_achievements_achievement_counters.SAC_ID
WHERE square_achievements_counters.eventObject = 'CommentEvent'
AND square_achievements_counters.eventType = 'add'
AND square_achievements_achievements.SAA_ID NOT IN
(
    SELECT square_achievements_achievements.SAA_ID 
    FROM square_achievements_achievements 
    JOIN square_achievements_user_achievements ON square_achievements_user_achievements.SAA_ID = square_achievements_achievements.SAA_ID
    WHERE square_achievements_user_achievements.UID = 83
)

如果可能,将此查询编写为连接会更有效吗?如果是这样,它将如何重写?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-01 20:37:08

代码语言:javascript
复制
SELECT  a.*
FROM    achievements a
JOIN    achievement_counters ac
ON      ac.saac_id = a.saa_id
JOIN    counters c
ON      c.sac_id = ac.sac_id
WHERE   c.eventObject = 'CommentEvent'
        AND c.eventType = 'add'
        AND a.saa_id NOT IN
        (
        SELECT  saa_id
        FROM    user_achievements 
        WHERE   uid = 83
        )

这是非常好的。

如果您想要连接,请使用以下命令:

代码语言:javascript
复制
SELECT  a.*
FROM    achievements a
JOIN    achievement_counters ac
ON      ac.saac_id = a.saa_id
JOIN    counters c
ON      c.sac_id = ac.sac_id
LEFT JOIN
        user_achievements ua
ON      ua.uid = 83
        AND ua.saa_id = a.saa_id
WHERE   c.eventObject = 'CommentEvent'
        AND c.eventType = 'add'
        AND ua.saa_id IS NULL
票数 1
EN

Stack Overflow用户

发布于 2012-06-01 20:37:52

我更喜欢使用相关名称来提高代码的可读性。

试试这个:

代码语言:javascript
复制
SELECT * 
FROM square_achievements_achievements a
JOIN square_achievements_achievement_counters b  ON b.SAAC_ID = a.SAA_ID 
JOIN square_achievements_counters c ON c.SAC_ID = b.SAC_ID 
JOIN square_achievements_user_achievements d on d.SAA_ID = a.SAA_ID 
JOIN square_achievements_user_achievements u on d.SAA_ID = u.SAA_ID AND u.UID = 83 
WHERE c.eventObject = 'CommentEvent' 
AND a.eventType = 'add' 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10850291

复制
相关文章

相似问题

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