比较两个表并使用MySQL LEFT OUTER JOIN返回缺少的ID

要比较两个表并返回缺少的ID,您需要使用MySQL LEFT OUTER JOIN。

让我们创建一个带有示例字段的表,然后插入记录。创建第一个表的查询-

第一表

mysql> create table First_Table
   -> (
   -> Id int
   -> );

现在,使用insert命令在表中插入一些记录。查询如下-

mysql> insert into First_Table values(1);
mysql> insert into First_Table values(2);
mysql> insert into First_Table values(3);
mysql> insert into First_Table values(4);

使用select语句显示表中的所有记录。查询如下-

mysql> select *from First_Table;

以下是输出-

+------+
| Id   |
+------+
|    1 |
|    2 |
|    3 |
|    4 |
+------+
4 rows in set (0.00 sec)

这是创建第二个表的查询-

Second_Table

mysql> create table Second_Table
   -> (
   -> Id int
   -> );

现在,您可以使用insert命令在表中插入一些记录。查询如下-

mysql> insert into Second_Table values(2);
mysql> insert into Second_Table values(4);

使用select语句显示表中的所有记录-

mysql> select *from Second_Table;

以下是输出-

+------+
| Id   |
+------+
|    2 |
|    4 |
+------+
2 rows in set (0.00 sec)

查询如下以比较两个表并使用LEFT OUTER JOIN返回缺少的ID-

mysql> SELECT First_Table.Id FROM First_Table
   -> LEFT OUTER JOIN Second_Table ON First_Table.Id = Second_Table.Id
   -> WHERE Second_Table.Id IS NULL;

以下是输出-

+------+
| Id   |
+------+
| 1    |
| 3    |
+------+
2 rows in set (0.00 sec)