search
HomeDatabaseMysql TutorialWhat is the execution process of Mysql table connection?

    1. Foreword

    For connection operations, we put the association conditions between the driving table and the driven table after on. If additional conditions for the driving table and the driven table are added, If the filter conditions of the driven table are placed after on or where, no error will be reported, but the result set obtained is different? ? ?

    1.1 The principle of mysql connection

    As we all know, mysql is based on the Nested-Loop Join (Nested-Loop Join, not considering the optimization algorithm for the time being) algorithm to perform connection operations between tables The general process is as follows:

    • Select the driver table and use the filter conditions related to the driver table to execute a single-table query on the driver table;

    • For each record in the queried driver table, search for matching records in the driven table.

    The pseudo code is as follows:

    for each row in t1 {      // 遍历满足对t1单表查询结果集中的每一条纪录
        for each row in t2 {  // 对于某条t1纪录,遍历满足对t2单表查询结果集中的每一条纪录
            if row satisfies join conditions, send to client
        }
    }

    1.2 show warnings command

    The sql statement we wrote is optimized by the optimizer It will then be handed over to the executor for execution, and the show warnings command can help us obtain the SQL optimized by the optimizer.

    2. Preparation

    The table structure is as follows:

    CREATE TABLE `student` (
      `id` bigint(20) NOT NULL AUTO_INCREMENT,
      `stu_code` varchar(20) NOT NULL DEFAULT '',
      `stu_name` varchar(30) NOT NULL DEFAULT '',
      `stu_sex` varchar(10) NOT NULL DEFAULT '',
      `stu_age` int(10) NOT NULL DEFAULT '0',
      `stu_dept` varchar(30) NOT NULL DEFAULT '',
      PRIMARY KEY (`id`) USING BTREE,
      UNIQUE KEY `uq_stu_code` (`stu_code`)
    ) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8mb4
    
    CREATE TABLE `course` (
      `id` bigint(20) NOT NULL AUTO_INCREMENT,
      `cou_code` varchar(20) NOT NULL DEFAULT '',
      `cou_name` varchar(50) NOT NULL DEFAULT '',
      `cou_score` int(10) NOT NULL DEFAULT '0',
      `stu_code` varchar(20) NOT NULL DEFAULT '',
      PRIMARY KEY (`id`) USING BTREE,
      KEY `idx_stu_code_cou_code` (`stu_code`,`cou_code`)
    ) ENGINE=InnoDB AUTO_INCREMENT=19 DEFAULT CHARSET=utf8mb4

    The table data is as follows:

    What is the execution process of Mysql table connection?

    3. The difference between inner join inner join on and where

    sql is as follows:

    select * from student
    inner join course on student.stu_code = course.stu_code
    and student.stu_code >= 3 and course.cou_score >= 80;

    Execute explain sql command:

    What is the execution process of Mysql table connection?

    Execute show warnings command:

    What is the execution process of Mysql table connection?

    Analysis: From the analysis of show warnings, For inner join connections, after optimization by the optimizer, the on connection conditions will be converted into where! In other words, where and on in inner connections are equivalent .

    4. The difference between left join left join on and where

    4.1 where driver table filter conditions

    sql is as follows:

    select * from student
    left join course on student.stu_code = course.stu_code
    where student.stu_code >= 3;

    Execute explain sql command:

    What is the execution process of Mysql table connection?

    Execute show warnings command:

    What is the execution process of Mysql table connection?

    Result set:

    What is the execution process of Mysql table connection?

    Analysis: From the explain analysis, student is used as the driver table, and student.stu_code >= 3 is used as a filter condition to perform a full table scan, and then the student.stu_code (that is, in the on condition) of each queried record is used as a filter condition to perform a single table query on the driven table course.

    4.2 on driver table filter conditions

    sql is as follows:

    select * from student
    left join course on student.stu_code = course.stu_code 
    and student.stu_code >= 3;

    Execute explain sql command:

    What is the execution process of Mysql table connection?

    Execute show warnings command:

    What is the execution process of Mysql table connection?

    ## Result set:

    What is the execution process of Mysql table connection?

    From the result set, student.stu_code >= 3 does not take effect. Why?

    Analysis: As can be seen from the explain analysis, student is used as the driver table to perform a full table scan, and then the student.stu_code and student.stu_code of each queried record are >= 3 (That is, in the on condition) are used as filter conditions to allow the driven table to perform single-table queries; At this time, student.stu_code >= 3 is not filtered for the driver table, and only takes effect when connecting to the driven table , the query cannot find matching records and returns NULL!

    4.3 On driven table filter conditions

    sql is as follows:

    select * from student
    left join course on student.stu_code = course.stu_code 
    and course.cou_score >= 80;

    Execute explain sql command:

    What is the execution process of Mysql table connection?

    Execute show warnings command:

    What is the execution process of Mysql table connection?

    ##Result set:

    Analysis: As can be seen from the explain analysis, student is used as the driving table to perform a full table scan, and then the student.stu_code and course.cou_score of each queried record are >= 80 (that is, ) in the on condition are used as filtering conditions to allow the driven table to perform single-table queries;

    4.4 where driven table filtering conditions

    sql is as follows:

    What is the execution process of Mysql table connection?

    Execute the explain sql command:

    What is the execution process of Mysql table connection?

    Execute the show warnings command:

    What is the execution process of Mysql table connection?

    Result set:

    What is the execution process of Mysql table connection?

    From the analysis of show warnings? Left join connection becomes inner join connection?

    Analysis: From the show warnings analysis, it can be seen that if the driven table has filter conditions in where, then the left join will be invalidated and optimized into an inner join connection. Therefore, the filter conditions of driven tables should be placed on instead of where.

    The above is the detailed content of What is the execution process of Mysql table connection?. For more information, please follow other related articles on the PHP Chinese website!

    Statement
    This article is reproduced at:亿速云. If there is any infringement, please contact admin@php.cn delete
    图文详解mysql架构原理图文详解mysql架构原理May 17, 2022 pm 05:54 PM

    本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

    mysql怎么去掉第一个字符mysql怎么去掉第一个字符May 19, 2022 am 10:21 AM

    方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

    mysql的msi与zip版本有什么区别mysql的msi与zip版本有什么区别May 16, 2022 pm 04:33 PM

    mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

    mysql怎么替换换行符mysql怎么替换换行符Apr 18, 2022 pm 03:14 PM

    在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

    mysql怎么将varchar转换为int类型mysql怎么将varchar转换为int类型May 12, 2022 pm 04:51 PM

    转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

    MySQL复制技术之异步复制和半同步复制MySQL复制技术之异步复制和半同步复制Apr 25, 2022 pm 07:21 PM

    本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

    带你把MySQL索引吃透了带你把MySQL索引吃透了Apr 22, 2022 am 11:48 AM

    本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

    mysql怎么判断是否是数字类型mysql怎么判断是否是数字类型May 16, 2022 am 10:09 AM

    在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

    See all articles

    Hot AI Tools

    Undresser.AI Undress

    Undresser.AI Undress

    AI-powered app for creating realistic nude photos

    AI Clothes Remover

    AI Clothes Remover

    Online AI tool for removing clothes from photos.

    Undress AI Tool

    Undress AI Tool

    Undress images for free

    Clothoff.io

    Clothoff.io

    AI clothes remover

    AI Hentai Generator

    AI Hentai Generator

    Generate AI Hentai for free.

    Hot Article

    Hot Tools

    Dreamweaver CS6

    Dreamweaver CS6

    Visual web development tools

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

    WebStorm Mac version

    WebStorm Mac version

    Useful JavaScript development tools

    Atom editor mac version download

    Atom editor mac version download

    The most popular open source editor

    MinGW - Minimalist GNU for Windows

    MinGW - Minimalist GNU for Windows

    This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.