zoukankan      html  css  js  c++  java
  • mysql 查询--去重

    INSERT INTO `material`(`id`,`file_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;

    注释:

    这是一个复制 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 ,也就不会插入数据,达到去重的效果

  • 相关阅读:
    最小费用最大流问题
    成大事必备9种能力、9种手段、9种心态
    转 fpga学习经验2
    算法 FFT理论1
    FPGA进阶之路1
    FPGA:亲和力激活竞争力
    1030 又回来了
    转 fpga学习经验1
    调查:近半大学生愿接受15002000元月薪
    转 观点:哪些人适合做FPGA开发(精华)
  • 原文地址:https://www.cnblogs.com/wsh-ning/p/9146005.html
Copyright © 2011-2022 走看看