我有一个简单的mysql表:

CREATE TABLE IF NOT EXISTS `pers` (
  `persID` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(35) NOT NULL,
  `gehalt` int(11) NOT NULL,
  `chefID` int(11) DEFAULT NULL,
  PRIMARY KEY (`persID`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=4 ;

INSERT INTO `pers` (`persID`, `name`, `gehalt`, `chefID`) VALUES
(1, 'blb', 1000, 3),
(2, 'as', 1000, 3),
(3, 'chef', 1040, NULL);

我试图运行以下更新,但我只得到错误1093:

UPDATE pers P 
SET P.gehalt = P.gehalt * 1.05 
WHERE (P.chefID IS NOT NULL 
OR gehalt < 
(SELECT (
    SELECT MAX(gehalt * 1.05) 
    FROM pers MA 
    WHERE MA.chefID = MA.chefID) 
    AS _pers
))

我搜索了这个错误,并从mysql下面的页面http://dev.mysql.com/doc/refman/5.1/en/subquery-restrictions.html找到,但它没有帮助我。

我该怎么做来纠正sql查询?


当前回答

在Mysql中,不能通过子查询来更新同一个表。

您可以将查询分成两部分,也可以这样做

 UPDATE TABLE_A AS A
 INNER JOIN TABLE_A AS B ON A.field1 = B.field1
 SET field2 = ? 

其他回答

在Mysql中,不能通过子查询来更新同一个表。

您可以将查询分成两部分,也可以这样做

 UPDATE TABLE_A AS A
 INNER JOIN TABLE_A AS B ON A.field1 = B.field1
 SET field2 = ? 

BlueRaja发布的方法很慢,我把它修改为 我用来从表中删除重复的数据。以防对大桌子的人有用 原始查询

DELETE FROM table WHERE id NOT IN (SELECT MIN(id) FROM table GROUP BY field 2)

这需要更多的时间:

DELETE FROM table WHERE ID NOT IN(
  SELECT MIN(t.Id) FROM (SELECT Id, field2 FROM table) AS t GROUP BY field2)

更快的解决方案

DELETE FROM table WHERE ID NOT IN(
   SELECT t.Id FROM (SELECT MIN(Id) AS Id FROM table GROUP BY field2) AS t)

MariaDB从10.3开始取消了这一规定。x (DELETE和UPDATE):

UPDATE -具有相同源和目标的语句 从MariaDB 10.3.2开始,UPDATE语句可以具有相同的源和目标。 在MariaDB 10.3.1之前,下面的UPDATE语句将不起作用: UPDATE t1 SET c1=c1+1 WHERE c2=(SELECT (c2) FROM t1); 错误1093 (HY000):表't1'被指定两次, 既是“UPDATE”的目标,也是数据的独立来源 在MariaDB 10.3.2中,语句执行成功: UPDATE t1 SET c1=c1+1 WHERE c2=(SELECT (c2) FROM t1);


DELETE -相同的源和目标表 在MariaDB 10.3.1之前,从具有相同源和目标的表中删除是不可能的。从MariaDB 10.3.1开始,现在这是可能的。例如: DELETE FROM t1 WHERE c1 IN (SELECT b.c1 FROM t1 WHERE b.c2=0);

DBFiddle MariaDB 10.2 -错误

DBFiddle MariaDB 10.3 -成功

其他的解决方法包括在子查询中使用SELECT DISTINCT或LIMIT,尽管它们对物化的影响并不明确。这对我很有效

如MySql文档中所述

这很简单。例如,不要写:

INSERT INTO x (id, parent_id, code) VALUES (
    NULL,
    (SELECT id FROM x WHERE code='AAA'),
    'BBB'
);

你应该写

INSERT INTO x (id, parent_id, code)
VALUES (
    NULL,
    (SELECT t.id FROM (SELECT id, code FROM x) t WHERE t.code='AAA'),
    'BBB'
);

或类似的。