External link operation summary: innerjoin & leftjoin & rightjoin_MySQL

Source: Internet
Author: User
External link operation summary innerjoinamp; leftjoinamp; rightjoin database operation statement

7. Outer join-cross query
7.1 Query
7.2 equijoin
7.3 right outer join
7.4 left outer join
7.5 update operations

Introduction:

External connection and self-connection
Inner join (equivalent join) returns only rows with equal join fields in two tables.
Left join returns records that include all records in the left table and join fields in the right table.
Right join returns records that include all records in the right table and the joined fields in the left table.
On specifies the equal sign "=" expression of the joined fields and their relationships between tables. true or false is returned. when the expression returns true, the query contains the record.
! An external connection can only operate on data that already exists in the database.

CODE:

7.5.2
UPDATE (ctarticle AS a left join ctclass AS c ON a. classid = c. classid) left join cttag AS B ON a. articleid = B. articleid
SET tag = tag + '', B. articleid = a. articleid, B. classid = a. classid, B. nclassid = a. nclassid
WHERE a. classid = 23 AND a. nclassid = 0 AND tagid is not null

7.5.1
UPDATE (ctarticle AS a left join (ctnclass AS c left join ctclass AS d ON c. classid = d. classid) ON. nclassid = c. nclassid AND. classid = c. classid) left join cttag AS B ON. articleid = B. articleid SET tag = d. class + ''+ c. nclass, B. articleid =. articleid, B. classid =. classid, B. nclassid =. nclassid
WHERE a. classid = 23 AND a. nclassid = 197;

7.5 update operations

74.5 filter data in LEFT JOIN
Insert into cttag (articleid, classid, nclassid) SELECT. articleid,. classid,. nclassid from ctarticle a left join cttag B on. articleid = B. articleid where B. articleid is null
// This statement function is used to display all the content of the master table and insert the data that is not in the secondary table.
// The main function is to reduce data redundancy.

7.4.4.1 continuation in the previous example
SELECT a. *, B. *, c. *, d .*
FROM cttag as d left join (ctarticle AS a left join ctclass AS B ON. classid = B. classid) left join ctnclass AS c ON. nclassid = c. nclassid) on d. articleid =. articleid;

7.4.4 show All in the document table and call the columns in the category table
Select. *, B. *, c. * from (ctarticle a left join ctclass B on. classid = B. classid) left join ctnclass c on. nclassid = c. nclassid
// Function. sometimes, an article table contains data that is not present in an individual category table. you can use this syntax to read all the data in the article table.
// A is the document table, B is the main category, and c is the subcategory.

7.4.3 in the preceding example, add a space when appending data.
Insert into cttag (articleid, classid, nclassid, tag)
SELECT a. articleid, a. classid, a. nclassid, d. class + ''+ c. nclass
FROM (ctarticle AS a left join (ctnclass c left join ctclass d on c. classid = d. classid) on. classid = c. classid and. nclassid = c. nclassid) left join cttag AS B ON. articleid = B. articleid where. classid = 4 and. nclassid= 154;

7.4.2 connect N tables and append data to one of them, N = 4
Insert into cttag (articleid, classid, nclassid, tag)
SELECT a. articleid, a. classid, a. nclassid, d. class + c. nclass
FROM (ctarticle AS a left join (ctnclass c left join ctclass d on c. classid = d. classid) on. classid = c. classid and. nclassid = c. nclassid) left join cttag AS B ON. articleid = B. articleid where. classid = 1 and. nclassid = 1;
// Explanation
Insert to Table 2 (Column 1, column 2, column 3, column 4)
Select alias a. column 1, alias a. column 2, alias a. column 3, alias d. column 4, alias c. column 5
From (Table 1 alias a left join (Table 3 alias c left join table 4 alias d in alias c. column 2 equals to alias d. column 2) in Alias. column 2 equals to alias c. column 2 and alias. column 3 = alias c. column 3) join Table 2 on the left. alias B is in Alias. column 1 equals to alias B. column 1 is alias. column 2 = 1 and alias. column 3 = 1

7.4.1 connect two tables and append data to one of them
Insert into cttag (articleid, classid, nclassid)
SELECT a. articleid, a. classid, a. nclassid
FROM ctarticle AS a left join cttag AS B ON a. articleid = B. articleid where a. classid = 1 and a. nclassid = 1;
// Explanation
Insert to Table 2 (Column 1, column 2, column 3)
Select alias a. column 1, alias a. column 2, alias a. column 3
From Table 1 alias a left join Table 2 alias B in Alias a. column 1 equals alias B. column 1 where alias a. column 4 = 1 and alias a. column 5 = 1

7.4. LEFT JOIN

7.3.1 synchronize data from two tables
UPDATE ctarticle a inner join cttag B ON a. articleid = B. articleid SET B. classid = a. classid, B. nclassid = a. nclassid;
// Explanation
Update Table 1 alias a join Table 2 Alias 2 in Alias. column 1 equals to alias B. column 1 sets the alias B. column 2 is updated to alias. column 2, alias B. column 3 is updated to alias. column 3

7.3 right outer join
Select a. *, B. * from bunclass a right join ctclass B on a. classid = B. classid where a. nclassid = 20
Query aliases a and B, and only match the content in Table B.

7.2.3 add data to a connection table
Insert into cttag (tag, articleid) SELECT top 1 B. tag,. articleid FROM ctarticle AS a left JOIN cttag AS B ON. articleid = B. articleid WHERE. articleid order by. articleid desc;

7.2.2 usage 2 in the work und
Insert into bureply
SELECT B. *, a. classid, a. nclassid
FROM article AS a inner join reply AS B ON a. articleid = B. articleid
WHERE classid = 50;

7.2.1 flexibility in Practical application
Insert into butag (tag, articleid, classid, nclassid)
SELECT B. tag, a. articleid, a. classid, a. nclassid
FROM article AS a inner join tag AS B ON a. articleid = B. articleid
WHERE classid = 24;

7.2 add data to other tables
Insert into butag (tag, articleid)
SELECT B. tag, a. articleid
FROM article AS a inner join tag AS B ON a. articleid = B. articleid
WHERE a. articleid <> False;
// Explanation
Add to receiving table (Column 1, column 2)
Select alias B. column 1, alias a. column 2
From Table 1 table name a join Table 2 table name B in Alias a. column c equals alias B. column c
Where is the alias? a. column c is not equal to no

7.1.1 Practical application
SELECT B. tag, a. articleid, a. classid, a. nclassid
FROM article AS a inner join tag AS B ON a. articleid = B. articleid
WHERE a. classid = 24;

7.1 Query
SELECT B. tag, a. articleid
FROM article AS a inner join tag AS B ON a. articleid = B. articleid
WHERE a. articleid <> False;
// Explanation
Select alias B. column, alias a. column
From Table 1 alias a join Table 2 alias B in Alias a. column c = alias B. column c
Where is the alias? a. column c is not equal to no
Note: as is not necessary

7. Outer join-cross query
Tip: Pay attention to the same columns in the table.

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.