INSERT INTO `material`(`id`,`file_url`)url
SELECT Id,EKM.`file_url`
FROM `extmaterial` AS EKM
LEFT JOIN ( SELECT `file_url` FROM `material` WHERE `id` = Id ) AS PM ON PM.`file_url` = EKM.`file_url`
WHERE EKM .`ext_id` = ExtId AND PM.`file_url` IS NULL;file
注释:数据
这是一个复制 URL 的语句。向 `material` 中复制 `extmaterial` 表中的信息,可是 extmaterial 有 material 中已存在和未存在的信息,因此须要去重。
查询
笔者比较笨,因此用中文来理解SQL语句:注释
INSERT INTO `material`(`a_id`,`file_url`) -- 向 material 中插入 (`id`,`file_url`)中文
SELECT AId,EKM.`file_url` FROM `extmaterial` AS EKM -- 在 extmaterial 表中查询 (`id`,`file_url`)去重
LEFT JOIN ( SELECT `file_url` FROM `material` WHERE `a_id` = AId ) AS PM ON PM.`file_url` = EKM.`file_url` -- 左联(查询 material 中的 符合条件 的 file_url 做为结果集)别名为 PM ,左联条件是 PM.`file_url` = EKM.`file_url` ,这个左联查询到的是相同的URL,
WHERE EKM .`ext_id` = ExtId AND PM.`file_url` IS NULL; -- 令 PM.`file_url` 的URL(也就是重复的URL)为NULL ,也就是当 extmaterial 查到的复合 EKM .`ext_id` = ExtId 条件的URL 而且 这个URL 等于 PM.`file_url`,就令这个数据为NULL ,也就不会插入数据,达到去重的效果