当前位置: 代码迷 >> SQL >> SQL去重有关问题
  详细解决方案

SQL去重有关问题

热度:67   发布时间:2016-05-05 13:27:57.0
SQL去重问题

DB2:

?delete from (select? a,row_number() over(partition by a order by a)? as b from a) where b<>1

?

oracle:

delete from hb_np_project_energy_diff where (rowid,deid) in (select min(rowid),deid from hb_np_project_energy_diff group by deid having count(deid)>1
)

?

SQLSERVER:

还没试

?

?mysql:

?

ALTER IGNORE TABLE data_statdata ADD UNIQUE(ts)

?

如何去除数据表中的重复数据利用数据导入导出的方式.这种方式是能实现的,数据建立唯一索引的.但有一个更为简单的方法,能达到这个目的.那就是 IGNORG,比如:

ALTER IGNORE TABLE `tbl_name` ADD UNIQUE (`un_name`);
tal_name 为表名,un_name唯一索引名.
IGNORE 是当出现错误时,也就是当前处理的记录,与前面处理过的数据的有冲突(重复),忽略之.使SQL继续进行,这样便把可以达到去重的目的.

引申:这个选项在insert中也存在.我们如果在一个执行过程中,有多个insert 时,不免会在唯一索引字段上会有重复的.那么,使用ignore 会使得insert继续进行.而不是中断

?

觉得不怎么样

  相关解决方案