要比较两个表并返回缺少的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)
这是创建第二个表的查询-
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)