比较两个表并在MySQL中返回缺少的ID?

要比较两个表并返回缺少的ID,您需要使用子查询。语法如下-

SELECT yourFirstTableName.yourIdColumnName FROM yourFirstTableName
WHERE NOT IN(SELECT yourSecondTableName.yourIdColumnName FROM youSecondTableName);

为了理解上述语法,让我们创建一个带有示例字段的表,然后插入记录。创建第一个表的查询-

第一表

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);
Display all records from the table using select statement:
mysql> select *from Second_Table;

以下是输出-

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

这是比较两个表并返回缺少的ID的查询-

mysql> select First_Table.Id from First_Table where
   -> First_Table.Id NOT IN(select Second_Table.Id from Second_Table);

以下是输出-

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