1

尝试通过使用INSERT INTO SELECT并连接两个源表来填充一个空的 MySQL 表。想要忽略基于定义为UNIQUE KEY的两个目标表列的重复行的插入,但由于某种原因,仍在插入基于这两个列的重复行。

目标表定义:

CREATE TABLE `item` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `item_id` int(10) unsigned NOT NULL,
  `account_id` int(10) unsigned NOT NULL,
  `creation_date` datetime NOT NULL,
  `modification_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),
  UNIQUE KEY `unique_item` (`item_id`,`account_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

插入查询:

INSERT IGNORE INTO item
            (id,
             item_id,
             account_id,
             creation_date,
             modification_date)
SELECT tblItem.ID,
       tblItem.itemID,
       tblOrder.accID,
       tblItem.itemTime,
       '0000-00-00 00:00:00'
FROM   tblItem
   INNER JOIN tblOrder
           ON tblItem.orderID = tblOrder.ID

重复的行被插入到类似于以下内容的项目中:

id    item_id   account_id  creation_date           modification_date
2587    0       2           11/19/11 2:43           0000-00-00 00:00:00
2575    0       1120        11/17/11 19:32          0000-00-00 00:00:00
2575    0       1120        11/17/11 19:32          0000-00-00 00:00:00
382     60      193         0000-00-00 00:00:00     0000-00-00 00:00:00
941     95      916         10/28/11 15:52          0000-00-00 00:00:00
369     108     1           0000-00-00 00:00:00     0000-00-00 00:00:00
373     108     2           0000-00-00 00:00:00     0000-00-00 00:00:00
378     109     2           0000-00-00 00:00:00     0000-00-00 00:00:00
378     109     2           0000-00-00 00:00:00     0000-00-00 00:00:00

我错过了什么?

提前致谢!

4

2 回答 2

7

尝试子句DISTINCT中的关键字:SELECT

INSERT IGNORE INTO item
        (id,
         item_id,
         account_id,
         creation_date,
         modification_date)
SELECT DISTINCT tblItem.ID,
   tblItem.itemID,
   tblOrder.accID,
   tblItem.itemTime,
   '0000-00-00 00:00:00'
FROM   tblItem
   INNER JOIN tblOrder
       ON tblItem.orderID = tblOrder.ID
于 2012-08-31T00:03:27.527 回答
0

CREATE TABLE语法中所述:

索引创建一个UNIQUE约束,使得索引中的所有值都必须是不同的。

您在 columns 上定义了一个复合索引(item_id,account_id),因此该约束只要求每条记录都具有这两个列的不同组合。

在上面的示例中,似乎违反此约束的唯一记录是:

+--------+---------+------------+------ --+----------------------+
| 编号 | item_id | account_id | 创建日期 | 修改日期 |
+--------+---------+------------+------ --+----------------------+
| 第2575章 0 | 1120 | 2011-11-17 19:32:00 | 0000-00-00 00:00:00 |
| 第2575章 0 | 1120 | 2011-11-17 19:32:00 | 0000-00-00 00:00:00 |
| 378 | 109 | 2 | 0000-00-00 00:00:00 | 0000-00-00 00:00:00 |
| 378 | 109 | 2 | 0000-00-00 00:00:00 | 0000-00-00 00:00:00 |
+--------+---------+------------+------ --+----------------------+

然而,这些记录似乎也违反了PRIMARY KEY约束id(即它们似乎是相同的记录)。您显示的输出不太可能确实是item您定义的表的摘录:您几乎可以肯定正在查看其他表或查询的内容。

一种可能的解释是您定义了TEMPORARY TABLE一个同名的,它隐藏了定义约束 的基础item表。应该有助于确认您指的是您认为的表以及该表已在其上定义了您期望的约束。UNIQUESHOW CREATE TABLE item;

如果您绝对确定该表确实包含重复的约束条目(如果列中有重复项,UNIQUE则将返回以下语句),您可以尝试使用执行一些表维护。TRUEidmyisamchk

SELECT EXISTS (SELECT * FROM item GROUP BY id HAVING COUNT(*) > 1);
于 2012-08-31T03:18:01.367 回答