如何合并MySQL表中的重复行

时间:2017-08-01 08:31:42

标签: mysql duplicates

我几乎完成了一个涉及客户和产品的项目,并且最终发现由于键入错误我们有重复的记录,销售人员不止一次地将同一个客户添加到数据库中。

我需要做的是通过比较客户名称和邮政编码来识别重复记录并合并产品,以便生成的更新产品字段与适用于他们的所有产品一致,但只有一个客户记录存在。

为了解释这一点,我举了一个小例子。

    DROP TABLE IF EXISTS `tblProducts`;
    CREATE TABLE `tblProducts` (
      `ID` int(10) DEFAULT NULL,
      `Customer` varchar(30) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
      `Postcode` varchar(30) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
      `Products` varchar(30) COLLATE utf8mb4_unicode_ci DEFAULT NULL
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

    INSERT INTO `tblProducts` VALUES ('1', 'Bradford', 'BR1 2HJ', '111&222&444');
    INSERT INTO `tblProducts` VALUES ('2', 'Bradford', 'BR1 2HJ', '222');
    INSERT INTO `tblProducts` VALUES ('3', 'Tanner', 'TE4 9PO', '777&333');
    INSERT INTO `tblProducts` VALUES ('4', 'Smythe', 'SM3 8KO', '111&222');
    INSERT INTO `tblProducts` VALUES ('5', 'Francis', 'FL2 6HG', '444&333');
    INSERT INTO `tblProducts` VALUES ('6', 'Tanner', 'TE4 9PO', '555');
    INSERT INTO `tblProducts` VALUES ('7', 'Peters', 'PE4 4PE', '444');
    INSERT INTO `tblProducts` VALUES ('8', 'Jeffrey', 'JE9 4JK', '444&555&888');
    INSERT INTO `tblProducts` VALUES ('9', 'Barnes', 'BA5 5AB', '999');
    INSERT INTO `tblProducts` VALUES ('10', 'Smythe', 'SM1 4GE', '888&777&222');

如果我们运行以下查询,您会看到我们有两个副本,分别是Bradford和Tanner。

    SELECT Customer, Postcode, COUNT(*) FROM tblProducts group by Customer, Postcode having count(*) > 1

    Customer    Postcode    COUNT(*)
    Bradford    BR1 2HJ     2
    Tanner      TE4 9PO     2

单独的重复记录是:

    Customer  Postcode  Products
    Bradford  BR1 2HJ   111&222&444
    Bradford  BR1 2HJ   222
    Tanner    TE4 9PO   777&333
    Tanner    TE4 9PO   555

我需要运行MySQL查询以合并客户和邮政编码的产品> 1'如上所述,最终结果将是:

    Customer  Postcode  Products
    Bradford  BR1 2HJ   111&222&444
    Tanner    TE4 9PO   777&333&555

请注意,第一条记录中只有222个实例,因为222已经存在。重复记录将从MySQL表中删除,因此只存在一条记录。

我必须承认,我认为这对于MySQL来说很容易实现,并且已经花了很多时间来研究合并行,合并字段,删除重复项以及找不到任何特别有用的内容。

如果有帮助,请链接到jsfiddle:http://sqlfiddle.com/#!9/966550/4/0

当我被困住时,有人可以帮忙吗。

非常感谢,

罗布

1 个答案:

答案 0 :(得分:1)

SELECT TP.Customer,TP.Postcode,TP.Products
FROM tblProducts TP
INNER JOIN
(
    SELECT MIN(ID) ID FROM tblProducts GROUP BY Customer, Postcode
)INNERTABLE  ON INNERTABLE.ID=TP.ID

您可以尝试以上查询。