zoukankan      html  css  js  c++  java
  • mysql 外连接的时候,条件在on后面和条件在where后面的区别

    最近使用mysql的时候碰到一个问题:当一个表外联另一个表的时候,将一些查询条件放在on后面和放在where后面不太一样:

    学生分数表stuscore:

    当查询语句如下(查询语句1):

    SELECT a.name,a.subject,a.score,a.stuid ,b.name,b.subject,b.score,b.stuid
    FROM stuscore a
    LEFT JOIN stuscore b ON a.subject=b.subject WHERE a.score >100

    查询结果如下:查询结果为空;

    当查询语句如下时(查询语句2):

    SELECT a.name,a.subject,a.score,a.stuid ,b.name,b.subject,b.score,b.stuid
    FROM stuscore a
    LEFT JOIN stuscore b ON a.subject=b.subject AND a.score >100

    查询的结果如下:

    我发现查询结果不为空,但是后面的字段都为空。

    总结原因:当条件放在on后面的时候(如查询语句2),后面的条件作为连接条件,如果不满足,则显示左的一条数据,由标的查询字段都用null填充;

        当条件放在where后面的时候(如查询语句1),后面的条件作为查询条件,是在连表以后,再过滤的条件,只要不满足就过滤掉,所以查询出来的结果为空。

        所以一定要知道外连接的查询原理。

  • 相关阅读:
    C++常用库函数
    ejabberd组成模块
    TCP/IP协议栈的基本工作原理
    erlang ets表
    erlang lists模块函数使用大全
    erlang-string
    erlang四大behaviour之四-supervisor
    erlang四大behaviour之三-gen_event
    erlang四大behaviour之二-gen_fsm
    erlang四大behaviour之一gen_server
  • 原文地址:https://www.cnblogs.com/yidaijiankuanzhongbuhui/p/8511476.html
Copyright © 2011-2022 走看看