mysql 查詢--去重

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 ,也就不會插入數據,達到去重的效果

相關文章
相關標籤/搜索