MySQL按条件删除报错You can't specify target table 'xxx' for update in FROM clause

经常使用mysql 的查询功能,比较少使用删除。最近在网上做了几个sql题,有一个删除的问题,本以为挺简单,确报出如题目的错误,在网上一搜索才发现了这个问题。谨以此作为自己的学习记录,至于答案本身网上已经有很多了,要感谢各位遇到此问题并给出答案的人们。

表:

+--------+---------+------+---------------+------------+----------+

| id   | xuehao  | name | kechengid | kecheng | fenshu |

+------+-----------+------+---------------+------------+-----------+

|    1 | 2005001 | 张三 |        1         |    数学    |    69      |

|    2 | 2005002 | 李四 |        1         |    数学    |    89      |

|    3 | 2005001 | 张三 |        1          |    数学    |    69     |

+------+------------+------+---------------+------------+----------+ 

需求就是删除除了id 之外,其余信息全部相同的冗余记录。

当时的思路即使先求出这些冗余的信息的一个最小id,只要这一条记录,不是最小id的记录删除就可以了。因此当时使用了这样的语句:

delete from tb02 where id not in (select min(id) from tb02 group by xuehao, name, kechengid, kecheng, fenshu) ;

结果就报错:

ERROR 1093 (HY000): You can't specify target table 'tb02' for update in FROM clause。

后来到网上搜索,原来是因为  在mysql中,不支持先 select 一个表的记录,在按此条件进行更新和删除同一个表的记录。

解决办法是,将select得到的结果,再通过中间表select一遍,这样就可以规避错误,这个问题只出现于mysql。oracle 并不会出现。

修改后的语句:

delete from tb02 where id not in (select t.id from (select min(id) as id from tb02 group by xuehao,name,kechengid,kecheng,fenshu ) t);

这样就顺利的删除了除了id 其余全部冗余的数据。


每天前进一小步,或许可以和乌龟一样长寿!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容

  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 7,790评论 5 116
  • 观其大纲 page 01 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 M...
    周少言阅读 3,155评论 0 33
  • 一. Java基础部分.................................................
    wy_sure阅读 3,805评论 0 11
  • 17年之后的世界是什么样子,很难去预测,因为世界轨迹的变化非常复杂,用学术性的语言来讲是混沌的,未来社会显著的变化...
    店长丿阅读 273评论 0 0
  • 青盦阅读 725评论 0 1