Maison base de données tutoriel mysql SQL中JOIN和UNION区别、用法及示例介绍

SQL中JOIN和UNION区别、用法及示例介绍

Jun 07, 2016 pm 06:07 PM
join union

join 是两张表做交连后里面条件相同的部分记录产生一个记录集,union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集

1.JOIN和UNION区别

join 是两张表做交连后里面条件相同的部分记录产生一个记录集,
union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集 。

JOIN用于按照ON条件联接两个表,主要有四种:
INNER JOIN:内部联接两个表中的记录,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。我理解的是只要记录不符合ON条件,就不会显示在结果集内。
LEFT JOIN / LEFT OUTER JOIN:外部联接两个表中的记录,并包含左表中的全部记录。如果左表的某记录在右表中没有匹配记录,则在相关联的结果集中右表的所有选择列表列均为空值。理解为即使不符合ON条件,左表中的记录也全部显示出来,且结果集中该类记录的右表字段为空值。
RIGHT JOIN / RIGHT OUTER JOIN:外部联接两个表中的记录,并包含右表中的全部记录。简单说就是和LEFT JOIN反过来。
FULL JOIN / FULL OUTER JOIN:完整外部联接返回左表和右表中的所有行。就是LEFT JOIN和RIGHT JOIN和合并,左右两表的数据都全部显示。

JOIN的基本语法:
Select table1.* FROM table1 JOIN table2 ON table1.id=table2.id

sql写法

内连接inner join:
代码如下:
SELECT msp.name, party.name
FROM msp JOIN party ON party=code


代码如下:
SELECT msp.name, party.name
FROM msp inner JOIN party ON party=code


左连接left join :
代码如下:
SELECT msp.name, party.name
FROM msp LEFT JOIN party ON party=code

右连接right join :
代码如下:
SELECT msp.name, party.name
FROM msp RIGHT JOIN party ON msp.party=party.code

全连接(full join):
代码如下:
SELECT msp.name, party.name
FROM msp FULL JOIN party ON msp.party=party.code


UNION运算符

将两个或更多查询的结果集组合为单个结果集,该结果集包含联合查询中的所有查询的全部行。UNION的结果集列名与UNION运算符中第一个Select语句的结果集的列名相同。另一个Select语句的结果集列名将被忽略。
其中两种不同的用法是UNION和UNION ALL,区别在于UNION从结果集中删除重复的行。如果使用UNION ALL 将包含所有行并且将不删除重复的行。

UNION和UNION ALL的区别:

union 检查重复
union all 不做检查
比如 select 'a' union select 'a' 输出就是一行 a
比如 select 'a' union all select 'a' 输出就是两行 a

2. 通过下面的例子,可以清晰的看出和理解2者的区别
实例1 典型的二表连接演示

假定有两个表Table1和Table2,其包含的列和数据分别如表1.1和表1.2所示。

表1.1 Table1数据库表

表1.2 Table2数据库表

Table1和Table2表共有的列为ColumnA,如果通过ColumnA列的值连接Table1和Table2两个表,即连接条件为Table1.ColumnA=Table2.ColumnA,此时得到的连接结果如表1.3所示。

表1.3 连接Table1和Table2表

上述连接过程的实现代码可表示如下:SELECT * FROM Table1 JOIN Table2 ON Table1.ColumnA=Table2.columnA

实例2 典型的二表记录的UNION运算

假定有两个表Table3和Table4,其包含的列和数据分别如表2.1和表2.2所示。

表2.1 Table3数据库表

表2.2 Table4数据库表、

Table3表和Table4表具有相同的列结构,列数也要相同,列名可以不同,以第一个表的列名为新表的列名,因此可以使用UNION运算符连接两个表的记录集,得到的连接结果如表2.3所示。

表2.3 使用UNION连接Table3表和Table4表的记录

上述连接过程的实现代码可表示如下:SELECT * FROM Table3 UNION SELECT *FROM Table4

对比实例1和实例2,不难发现二者的区别。

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser JOIN dans MySql Comment utiliser JOIN dans MySql Jun 04, 2023 am 08:02 AM

La signification de JOIN est similaire au mot anglais "join". Il joint deux tables et peut être grossièrement divisé en jointure interne, jointure externe, jointure droite, jointure gauche et jointure naturelle. Créez d'abord deux tables, ce qui suit est utilisé comme exemple CREATETABLEt_blog(idINTPRIMARYKEYAUTO_INCREMENT,titleVARCHAR(50),typeIdINT);SELECT*FROMt_blog;+----+------+--------+ | identifiant|titre|typeId|+----+-------+--------+|1|aaa|1||2|bbb|2||3|ccc|3 |

Quel est le principe d'utilisation de MySQL Join ? Quel est le principe d'utilisation de MySQL Join ? May 26, 2023 am 10:07 AM

Le type de jointure leftjoin utilise la table de gauche comme table de pilotage et la table de gauche comme base de l'ensemble de résultats. Les données de la table de droite sont connectées à l'ensemble de résultats. rightjoin utilise la table de droite comme table de pilotage et la table de droite comme. la base de l'ensemble de résultats pour connecter la table de gauche. Les données sont ajoutées à l'ensemble de résultats innerjoin. L'ensemble de résultats prend l'intersection des deux tables. L'ensemble de résultats prend l'union des deux tables MySQL. fulljoin. La différence entre union et unionall est que l'union dédupliquera le produit cartésien de jointure croisée. Si la condition Where n'est pas utilisée, l'ensemble de résultats sera le produit des deux lignes de table associées. défini, il sera transmis conformément à la condition.

Comment utiliser l'union en langage C Comment utiliser l'union en langage C Sep 27, 2023 am 11:00 AM

L'utilisation de l'union en langage C est un type de données spécial qui permet de stocker différents types de données dans le même emplacement mémoire. L'utilisation de l'union peut nous aider à économiser de l'espace mémoire et à faciliter la conversion entre différents types de données. Lorsque vous utilisez union, vous devez noter que le membre correspondant est valide et qu’un seul membre est accessible en même temps.

Comment utiliser JOIN dans MySQL Comment utiliser JOIN dans MySQL Jun 03, 2023 am 09:30 AM

Introduction A's unique + AB's public B's unique + AB's public AB's public A's unique B's unique A's unique + B's unique + AB's public A's unique + B's unique Entraînement à créer des tables de départements DROPTABLEIFEXISTS`dept`;CREATETABLE`dept`(`dept_id`int( 11)NOTNULLAUTO_INCREMENT,`nom_dept`varchar(30)DEFAULTNULL,`numéro_dept`int(11)DEFAULTNULL,PRIMARYKEY(`id_dept`))ENGINE =InnoDBAUT

Que sont la requête de jointure de MySQL et les méthodes de requête multiples ? Que sont la requête de jointure de MySQL et les méthodes de requête multiples ? Jun 02, 2023 pm 04:29 PM

Par rapport à la requête de jointure et aux requêtes multiples, laquelle est la plus efficace, la requête MySQL multi-table ou la requête multiple à table unique ? Lorsque la quantité de données n'est pas suffisamment importante, l'utilisation de la jointure ne pose aucun problème, mais elle se fait généralement au niveau de la couche de service. Premièrement : les ressources informatiques d'une base de données autonome sont très coûteuses et la base de données doit servir à la fois à l'écriture. et lire en même temps, ce qui nécessite une consommation de processeur. Afin de rendre la base de données, le débit devient plus élevé et l'entreprise ne se soucie pas de l'écart de retard de centaines de microsecondes à millisecondes. L'entreprise mettra plus de calculs dans la couche de service. Après tout, les ressources informatiques peuvent être facilement étendues horizontalement et les bases de données sont difficiles, donc la plupart des entreprises placeront des opérations informatiques pures dans la couche de service et utiliseront la base de données comme un système kv avec des capacités de transaction.

Comment utiliser la fonction FULL OUTER JOIN dans MySQL pour obtenir l'union de deux tables Comment utiliser la fonction FULL OUTER JOIN dans MySQL pour obtenir l'union de deux tables Jul 26, 2023 pm 05:45 PM

Comment utiliser la fonction FULLOUTERJOIN dans MySQL pour obtenir l'union de deux tables. Dans MySQL, la fonction FULLOUTERJOIN est une opération de jointure puissante qui combine des jointures internes et des jointures externes. Il peut être utilisé pour obtenir l'union de deux tables, c'est-à-dire combiner toutes les données des deux tables en un seul ensemble de résultats. Cet article présentera l'utilisation de la fonction FULLOUTERJOIN et fournira des exemples de code pour aider les lecteurs à mieux comprendre. Fonction FULLOUTERJOIN

Comment utiliser l'union MySQL pour implémenter une requête de jointure externe complète Comment utiliser l'union MySQL pour implémenter une requête de jointure externe complète May 30, 2023 pm 06:49 PM

1. L'Union n'est pas une méthode de requête de connexion multi-tables. Elle combine les résultats de requête de plusieurs phrases de requête en un seul résultat et supprime les données en double. 2. La jointure externe complète interroge les données de la table de gauche et de la table de droite, puis se connecte selon les conditions de connexion. Exemple #Utilisez l'Aunion externe gauche et l'externe droit BSELECT*FROMt_categorycLEFTOUTERJOINt_productpONc.cid=p.cnounionSELECT*FROMt_categorycRIGHTOUTERJOINt_productpONc.cid=p.cno

Comment Java définit-il la classe Union pour réaliser la coexistence des corps de données ? Comment Java définit-il la classe Union pour réaliser la coexistence des corps de données ? May 14, 2023 pm 03:34 PM

Définissez la classe Union pour implémenter la coexistence de corps de données. Dans le langage C/C++, une union, également appelée union, est une structure de données similaire à une structure. Une union, comme une structure, peut contenir de nombreux types de données et variables. La différence entre les deux est la suivante : toutes les variables d'une structure « coexistent » et toutes les variables sont valides en même temps. Chaque variable occupe différents espaces mémoire ; dans une union, chaque variable est « mutuellement exclusive », une seule variable est efficace en même temps et toutes les variables occupent le même espace mémoire. Lorsque plusieurs données doivent partager la mémoire ou qu'une seule donnée parmi plusieurs doit être prise à la fois, une union peut être utilisée. en Java

See all articles