SQL DISTINCT重复的数据统计方法 group by 重复数据的个数统计 删除重复的数据2008-09-10 16:30DISTINCT 关键字可从 SELECT 语句的结果中除去重复的行。如果没有指定 DISTINCT,那么将返回所有行,包括重复的行。
lect count(distinct t.destaddr) from nbyd_nd t where t.input_time > to_date('2007-2-1','yyyy-mm-dd') and t.input_time < to_date('2007-3-1','yyyy-mm-dd')
可以统计出一个月中的用户数量。
关于如何快速得知里面每一个号码重复的个数问题的解答:利用分组函数的SQL语句
l,count(*) from nbyd_deliver t group l ;group by 解决重复数据的个数统计适用于各种关系型数据库,如oracle,SQL Server
查询重复的数据
lect * from (lect v.xh,count(v.xh) num from sms.vehicle v group by v.xh) where num>1;--169
lect v.xh,count(v.xh) num from sms.vehicle v group by v.xh having count(v.xh)=2;江苏财政会计网
我的愿望600字作文
删除重复的数据
create table mayong as (lect distinct* from sms.vehicle);
delete from sms.vehicle ;
inrt into sms.vehicle lect * from mayong;
在oracle中,有个隐藏了自动rowid,里面给每条记录一个唯一的rowid,我们如果想保留最新的一条记录,我们就可以利用这个字段,保留重复数据中rowid最大的一条记录就可以了。
教龄怎么算
下面是查询重复数据的一个例子:
wid,a.* from 表名 a
平面设计实习报告wid !=
(
lect wid) from 表名 b 二年级上数学
where a.字段1 = b.字段1 and
强筋壮骨a.字段2 = b.字段2
)
下面我就来讲解一下,上面括号中的语句是查询出重复数据中rowid最大的一条记录。
而外面就是查询出除了rowid最大之外的其他重复的数据了。
由此,我们要删除重复数据,只保留最新的一条数据,就可以这样写了:
delete from 表名 a
企业档案管理办法wid !=
(
lect wid) from 表名 b
where a.字段1 = b.字段1 and
a.字段2 = b.字段2
)
随便说一下,上面语句的执行效率是很低的,可以考虑建立临时表,讲需要判断重复的字段、rowid插入临时表中,然后删除的时候在进行比较。
create table 临时表 as
lect a.字段1,a.字段2,MAX(a.ROWID) dataid from 正式表 a GROUP BY a.字段1,a.字段2;
delete from 表名 a
wid !=
(
炸鸡排
lect b.dataid from 临时表 b
where a.字段1 = b.字段1 and
a.字段2 = b.字段2
);
commit;
二、对于完全重复记录的删除
对于表中两行记录完全一样的情况,可以用下面语句获取到去掉重复数据后的记录:
lect distinct * from 表名
可以将查询的记录放到临时表中,然后再将原来的表记录删除,最后将临时表的数据导回原来的表中。如下:
CREATE TABLE 临时表 AS (lect distinct * from 表名);
delete from table 正式表;
inrt into 正式表 (lect * from 临时表);
drop table 临时表;