方法一: SELECT 序号= (SELECT COUNT(客户编号) FROM 客户 AS a WHERE a.客户编号<= b.客户编号), 客户编号,公司名称 FROM 客户 AS b ORDER BY 1; 方法二:
SELECT 序号= COUNT(*), a.客户编号, a.公司名称FROM 客户 AS a, 客户 AS b WHERE a.客户编号>= b.客户编号 GROUP BY a.客户编号, b.公司名称 ORDER BY 序号; 2. SQL Server 2005 构造序号列
方法一: SELECT RANK() OVER (ORDER BY 客户编号 DESC) AS 序号, 客户编号,公司名称 FROM 客户;
方法二: WITH TABLE AS (SELECT ROW_NUMBER() OVER (ORDER BY 客户编号 DESC) AS 序号, 客户编号,公司名称 FROM 客户) SELECT * FROM TABLE WHERE 序号 BETWEEN 1 AND 3; 3. Oracle 里 rowid 也可看做默认标识列 在Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,rowid确定了每条记录是在Oracle中的哪一个数据文件、块、行上。 在重复的记录中,可能所有列的内容都相同,但rowid不会相同,所以只要确定出重复记录中那些具有最大rowid的就可以了,其余全部删除。
复制代码 代码如下:
select * from test;select * from test group by id having count(*)>1select * from test group by idselect distinct * from testdelete from test a where a.rowid!=(select max(rowid) from test b where a.id=b.id);扯远了,回到原来的问题,除了采用数据结构的思想来处理,因为数据库特有的事务处理,能够把数据缓存在线程池里,这样也相当于临时表的功能,所以,我们还可以用游标来解决删除重复记录的问题。 declare @max int, @id int declare cur_rows cursor local for select id ,count(*) from test group by id having count(*) > 1 open cur_rows fetch cur_rows into @id ,@max while @@fetch_status=0 begin select @max = @max -1 set rowcount @max --让这个时候的行数等于少了一行的统计数,想想看,为什么 delete from test where id = @id fetch cur_rows into @id ,@max end close cur_rows set rowcount 0 以上是闪电查阅一些资料写出的想法,有考虑不周的地方,欢迎大家指出。