51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 24677|回复: 0
打印 上一主题 下一主题

left join、right join、inner join关联查询时出现重复数据

[复制链接]
  • TA的每日心情
    无聊
    2024-7-12 13:16
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    跳转到指定楼层
    1#
    发表于 2019-4-10 15:58:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    先放一条 重复数据 的脏SQL
    1. SELECT O.ID AS ID,O.NAME AS NAME,COUNT(C.ID) AS CLASS_NUM FROM T_BASE_ORGANIZATION O
    2. LEFT JOIN T_XSXX_CLASSINFORMATION C ON O.ID = C.FACULTY_ID
    3. LEFT JOIN T_SZDW_CLASSMEETING_PLAN P ON C.ID = P.CLASS_ID
    4. WHERE C.GRADE = 2010
    5. GROUP BY O.ID,O.NAME,O.ORDERS
    6. ORDER BY O.ORDERS
    复制代码
    这表结构是:
    T_BASE_ORGANIZATION 学院表
    T_XSXX_CLASSINFORMATION 班级表
    T_SZDW_CLASSMEETING_PLAN 班会表
    一个学院 多个班级
    一个班级 多个班会
    总之引发查询出重复数据就是因为,表之间关联的关系不是一对一的,导致数据重复。
    解决方式
    1. 方法一:在 GROUP BY 加上(多表的外键) C.ID
    2. SELECT O.ID AS ID,O.NAME AS NAME,COUNT(C.ID) AS CLASS_NUM FROM T_BASE_ORGANIZATION O
    3. LEFT JOIN T_XSXX_CLASSINFORMATION C ON O.ID = C.FACULTY_ID
    4. LEFT JOIN T_SZDW_CLASSMEETING_PLAN P ON C.ID = P.CLASS_ID
    5. WHERE C.GRADE = 2010
    6. GROUP BY O.ID,O.NAME,O.ORDERS,C.ID
    7. ORDER BY O.ORDERS

    8.    

    9. 方法二:在返回结果数据的 地方加上DISTINCT函数, COUNT(DISTINCT(C.ID))
    10. SELECT O.ID AS ID,O.NAME AS NAME,COUNT(DISTINCT(C.ID)) AS CLASS_NUM FROM T_BASE_ORGANIZATION O
    11. LEFT JOIN T_XSXX_CLASSINFORMATION C ON O.ID = C.FACULTY_ID
    12. LEFT JOIN T_SZDW_CLASSMEETING_PLAN P ON C.ID = P.CLASS_ID
    13. WHERE C.GRADE = 2010
    14. GROUP BY O.ID,O.NAME,O.ORDERS
    15. ORDER BY O.ORDERS


    16. 方法三:在做left join、right join、inner join的时候将 关联的表先DISTINCT(外键) 子查询一遍   
    17. SELECT O.ID AS ID,O.NAME AS NAME,COUNT(C.ID) AS CLASS_NUM FROM T_BASE_ORGANIZATION O
    18. LEFT JOIN T_XSXX_CLASSINFORMATION C ON O.ID = C.FACULTY_ID
    19. LEFT JOIN (SELECT DISTINCT(Z.CLASS_ID) FROM T_SZDW_CLASSMEETING_PLAN Z ) P ON C.ID = P.CLASS_ID
    20. WHERE C.GRADE = 2010
    21. GROUP BY O.ID,O.NAME,O.ORDERS
    22. ORDER BY O.ORDERS
    复制代码
    不推荐 使用方法一
    ORDER BY 函数 影响范围广。
    推荐使用方法一
    子查询 作用范围小,不影响整体SQL。


    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-22 20:07 , Processed in 0.061995 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表