• ADADADADAD

    mysql内连接和外连接有哪些区别[ mysql数据库 ]

    mysql数据库 时间:2024-11-25 14:55:52 热度:1℃

    作者:文/会员上传 下载docx

    简介:

    mysql内连接和外连接的区别:内连接会取出连接表中匹配到的数据,匹配不到的不保留;而外连接会取出连接表中匹配到的数据,匹配不到的也会保留,其值为NULL。本教程操作环境:windows7

    以下为本文的正文内容,请查阅,本站为公益性网站,复制本文以及下载DOC文档全部免费。

    mysql内连接和外连接的区别:内连接会取出连接表中匹配到的数据,匹配不到的不保留;而外连接会取出连接表中匹配到的数据,匹配不到的也会保留,其值为NULL。

    本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

    区别

      内连接(inner join):取出连接表中匹配到的数据,匹配不到的不保留

      外连接(outer join):取出连接表中匹配到的数据,匹配不到的也会保留,其值为NULL

      示例表

      users表

      mysql>select*fromusers;+----+-------+|id|name|+----+-------+|1|john||2|May||3|Lucy||4|Jack||5|James|+----+-------+5rowsinset(0.00sec)

      topics表

      mysql>select*fromtopics;+----+---------------------------------------+---------+|id|title|user_id|+----+---------------------------------------+---------+|1|Helloworld|1||2|PHPisthebestlanguageintheworld|2||3|Laravelartist|6|+----+---------------------------------------+---------+3rowsinset(0.00sec)
      内连接(inner join)

        示例

        mysql>select*fromusersasuinnerjointopicsastonu.id=t.user_id;+----+------+----+---------------------------------------+---------+|id|name|id|title|user_id|+----+------+----+---------------------------------------+---------+|1|john|1|Helloworld|1||2|May|2|PHPisthebestlanguageintheworld|2|+----+------+----+---------------------------------------+---------+2rowsinset(0.00sec)

        inner可以省略,as是给表起别名,也可以省略

        mysql>select*fromusersujointopicstonu.id=t.user_id;+----+------+----+---------------------------------------+---------+|id|name|id|title|user_id|+----+------+----+---------------------------------------+---------+|1|john|1|Helloworld|1||2|May|2|PHPisthebestlanguageintheworld|2|+----+------+----+---------------------------------------+---------+2rowsinset(0.00sec)

        以上两句等价于

        mysql>select*fromusers,topicswhereusers.id=topics.user_id;+----+------+----+---------------------------------------+---------+|id|name|id|title|user_id|+----+------+----+---------------------------------------+---------+|1|john|1|Helloworld|1||2|May|2|PHPisthebestlanguageintheworld|2|+----+------+----+---------------------------------------+---------+2rowsinset(0.00sec)
        外连接(outer join)

          左外连接(left outer join):以左边的表为主表

          右外连接(right outer join):以右边的表为主表

          以某一个表为主表,进行关联查询,不管能不能关联的上,主表的数据都会保留,关联不上的以NULL显示

          通俗解释就是:先拿出主表的所有数据,然后到关联的那张表去找有没有符合关联条件的数据,如果有,正常显示,如果没有,显示为NULL

          示例

          mysql>select*fromusersasuleftjointopicsastonu.id=t.user_id;+----+-------+------+---------------------------------------+---------+|id|name|id|title|user_id|+----+-------+------+---------------------------------------+---------+|1|john|1|Helloworld|1||2|May|2|PHPisthebestlanguageintheworld|2||3|Lucy|NULL|NULL|NULL||4|Jack|NULL|NULL|NULL||5|James|NULL|NULL|NULL|+----+-------+------+---------------------------------------+---------+5rowsinset(0.00sec)

          等价于以下,只是字段的位置不一样

          mysql>select*fromtopicsastrightjoinusersasuonu.id=t.user_id;+------+---------------------------------------+---------+----+-------+|id|title|user_id|id|name|+------+---------------------------------------+---------+----+-------+|1|Helloworld|1|1|john||2|PHPisthebestlanguageintheworld|2|2|May||NULL|NULL|NULL|3|Lucy||NULL|NULL|NULL|4|Jack||NULL|NULL|NULL|5|James|+------+---------------------------------------+---------+----+-------+5rowsinset(0.00sec)

          左外连接和右外连接是相对的,主要就是以哪个表为主表去进行关联

    mysql内连接和外连接有哪些区别.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysql
    ADADAD