Detailed explanation of MySQL multi-table join query

Detailed explanation of MySQL multi-table join query

Multi-table join query

The connection between tables is divided into inner connection and outer connection

  • Inner join: select only the records that match each other in two tables
  • Outer join: includes both matching records and unmatched records in two tables. Outer join is divided into left outer join (left join) and right outer join (right join)

Inner Join

First, prepare two tables

Student table

insert image description here

Score table

insert image description here

Inner join: Find the common records that meet the conditions in each table. Query the student names and scores in the student table.

The first way to write: only use where

select a.s_name, b.s_score from student a,score b where a.s_id = b.s_id;

The second way to write it: join ... on ...

select a.s_name, b.s_score from student a join score b on a.s_id = b.s_id

The third way to write it: inner join … on…

select a.s_name, b.s_score from student a inner join score b on a.s_id = b.s_id

insert image description here

Left Join

Left join: According to the records in the left table, find the records that meet the conditions in the connected right table to match them. If no records matching the left table are found, null is used to represent them.

The first way to write it: left join … on …

select a.s_name,b.s_score from student a left join score b on a.s_id = b.s_id

The second way of writing: left outer join … on …

select a.s_name,b.s_score from student a left outer join score b on a.s_id = b.s_id

insert image description here

Right Join

**Right join: **According to the records in the right table, find the records that meet the conditions in the connected left table to match them. If no match is found, it is represented by null.

The first way to write it: right join … on …

select a.s_name,b.s_score from student a right join score b on a.s_id = b.s_id;

The second way of writing: right outer join … on …

select a.s_name,b.s_score from student a right outer join score b on a.s_id = b.s_id;

insert image description here

Subqueries

Subquery : It is a way to implement multi-table join query. Another select statement is nested in the from clause or where clause of a select statement. The outer select query statement becomes the main query. In other words , the query statement in WHERE or FORM is called a subquery.

Subquery in WHERE clause: The value returned by the subquery is used as the query condition of the main query

Subquery in the FROM clause: The subquery returns a virtual table, and the main query finds the conditions that meet the conditions from the temporary table.

Summarize

This article ends here. I hope it can be helpful to you. I also hope that you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • Problems with join queries and subqueries in MySQL
  • What kinds of MYSQL connection queries do you know?
  • The principle and application of MySQL connection query
  • Mysql join query syntax and examples
  • Detailed explanation of the principles and usage examples of MySQL join query, union query, and subquery
  • Detailed explanation of Mysql self-join query example
  • MySQL multi-table join query example explanation
  • Detailed explanation of mysql connection query

<<:  Linux operation and maintenance basics httpd static web page tutorial

>>:  How to use CSS3 to implement a queue animation similar to online live broadcast

Recommend

Vue-Element-Admin integrates its own interface to realize login jump

1. First look at the request configuration file, ...

Detailed explanation of the use of Vue.js render function

Vue recommends using templates to create your HTM...

Introducing multiple custom fonts in CSS3

Today I found a problem in HTML. There are many d...

Vue implements adding watermark effect to the page

Recently, when I was working on a project, I was ...

Analyzing ab performance test results under Apache

I have always used Loadrunner to do performance t...

Graphic tutorial on installing Ubuntu 18.04 on VMware 15 virtual machine

In the past few years, I have been moving back an...

HTML page adaptive width table

In the pages of WEB applications, tables are ofte...

A brief discussion on whether too many MySQL data queries will cause OOM

Table of contents Impact of full table scan on th...

Detailed steps for using jib for docker deployment in Spring Cloud

Introduction to Jib Jib is a library developed by...

MySQL uses UNIQUE to implement non-duplicate data insertion

SQL UNIQUE constraint The UNIQUE constraint uniqu...

Graphic tutorial on installing CentOS7 on VMware 15.5

1. Create a new virtual machine in VMware 15.5 1....