Mysql删除重复数据保留最小的id 的解决方法
在网上查找删除重复数据保留id最小的数据,方法如下:
DELETE FROM people WHERE peopleNameIN( SELECT peopleName FROM people GROUPBY peopleName HAVING count(peopleName)>1 ) ANDpeopleIdNOTIN( SELECT min(peopleId) FROM people GROUPBY peopleName HAVING count(peopleName)>1 )
自己使用的时候显示报错:
deletefromtbwhereidin(SELECTmax(id)fromtbGROUPBYuserHAVINGcount(user)>1)
[Err]1093-Youcan'tspecifytargettable‘XXX'forupdateinFROMclause
暂时不知道是什么原因导致的。
然后想办法分布操作,首先筛选出有重复user的数据,然后用max()选出其中较大的那一行:
SELECTmax(id)fromtbGROUPBYuserHAVINGcount(user)>1
然后再根据得到的max(id)逐条删除多余的数据
deletefromtbwhereid=xx
是个笨方法,暂时先解决问题吧。
总结
以上所述是小编给大家介绍的Mysql删除重复数据保留最小的id的解决方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。