如果MySQL中的另一个表中存在行,则从一个表中删除行

时间:2012-10-08 03:17:53

标签: mysql sql-delete

我正在从旧的培训跟踪系统迁移数据,我正在使用MySQL格式化新培训跟踪系统的数据。

我有一个包含550万行的表,它是旧系统的主数据集。我还有一个大约49,000行的表,之前已经迁移过了。

我要做的是比较两个表并从主数据文件中删除先前已迁移的记录(我不想在新系统中创建重复记录。)

为了进行比较,我需要比较3个字段(employee_id,course_code和completion_date。)我正在使用以下SQL语句,但它只是坐着并旋转。我不知道它是否有效,只是花了很长时间,或者它真的不起作用。

DELETE master_data.*
FROM master_data
INNER JOIN alreadyMigrated
ON master_data.employee_id = alreadyMigrated.employee_id 
AND master_data.course_code = alreadyMigrated.course_code
AND master_data.completion_date = alreadyMigrated.completion_date;

我也不知道索引是否会有所帮助。任何帮助,将不胜感激。感谢。

1 个答案:

答案 0 :(得分:3)

您只需指定表名,而不是列。

DELETE master_data
       FROM master_data
       INNER JOIN alreadyMigrated
          ON master_data.employee_id = alreadyMigrated.employee_id AND 
             master_data.course_code = alreadyMigrated.course_code AND 
             master_data.completion_date = alreadyMigrated.completion_date;