我正在从旧的培训跟踪系统迁移数据,我正在使用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;
我也不知道索引是否会有所帮助。任何帮助,将不胜感激。感谢。
答案 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;