月小升今天遇到的问题是students这个表有md这个字段重复。看看如何处理吧。
| 代码如下 | 复制代码 |
|
select * from students |
|
注明,这个被group的字段,请索引,否则很慢
| 代码如下 | 复制代码 |
| delete from students where md in (select md from students group by md having count(md) > 1) and id not in (select min(id) from students group by md having count(md )>1) |
|
这个语句在mysql下会报错
#1093 – You can’t specify target table ‘students’ for update in FROM clause
原因是好像mysql不准许我们进行联合删除内有条件语句指向自己的表。
策略是使用临时表,存储那些要删除的ID
| 代码如下 | 复制代码 |
|
create table tmp (id int); insert into tmp (id) select id from students delete from students where id in (select id from tmp); |
|
得出会被删除的数据
| 代码如下 | 复制代码 |
|
select * from students |
|
得出过滤后的数据,不删除的数据。如果不用删除,此sql语句可以用来显示唯一数据
| 代码如下 | 复制代码 |
|
select * from students |
|
创造与魔法九游版本
创造与魔法九游版采用了极致创新的魔幻游戏玩法感受,游戏具备最
疯狂医院达什医生中文版(Crazy Hospital)
疯狂医院达什医生最新版是一款医院模拟经营类游戏,逼真的场景画
宝宝庄园官方版
宝宝庄园官方版是一款超级经典好玩的模拟经营类型的手游,这个游
桃源记官方正版
桃源记是一款休闲娱乐类的水墨手绘风格打造的模拟经营手游。玩家
长途巴士模拟器手机版
长途巴士模拟器汉化版是一款十分比真好玩的大巴车模拟驾驶运营类