如何快速删除Access指定字段的重复记录

如何快速删除Access指定字段的重复记录 Delphi / Windows SDK/API
http://www.delphi2007.net/DelphiDB/html/delphi_20061223120244146.html
我有一个ACCESS数据表如下  
  ID     Name       Score  
  1       老张       80  
  2       王二小   70  
  3       老张       80  
  4       李小黑   90  
  ====================  
  现在我想删除   字段   Name   重复的纪录,达如下效果:  
  ID     Name       Score  
  1       老张       80  
  2       王二小   70  
  4       李小黑   90  
   
  请问,在DELPHI里面操作ACCESS怎么做最快?  
  我查询了CSDN见到一个人操作ACCESS用了这样的表达式:“  
   
  这个是公认的最快的删除重复记录的SQL:        
           
      DELETE       FROM       EMP       E     WHERE       E.ROWID       >       (SELECT       MIN(X.ROWID)   FROM       EMP       X       WHERE       X.EMP_NO       =       E.EMP_NO);           ”  
   
  我自己如果要做,应该怎么做速度最快呢?    
   
  请给出思路  
 

你这个问题好像没什么好办法,  
  这样做吧,  
  Function   GetDelReocrdsID:   string;  
  var  
      midStr,ResultStr:string;  
  begin  
        with   adodataset   do  
        begin  
            if   active   then   active:=false;  
            commandtext:='select   *   from   EMP   order   by   [Name]   asc'   ;   //   一定要排序  
            open;   midStr:='';   ResultStr:='';  
            while   (Not   eof)   do  
            begin  
                if   trim(midstr)=trim(FieldByName('Name').asstring)   then  
                ResultStr:=ResultStr+FieldByName('ID').asstring+',';  
                else   midStr:=FieldByName('Name').asstring;        
                Next;  
            end;  
            if   result<>''   then  
            result:=Copy(ResultStr1,length(ResultStr)-1)  
            else   result:='-1'  
            Close;      
        end;  
  end;  
   
  procedure   deleteSelectRecord;  
  begin  
        with   Adocommand   do  
        begin  
              commandtext:='Delete   From   EMP   where   ID   in   ('+GetDelReocrdsID+')';  
              execute;  
        end;  
  end;

转载于:https://www.cnblogs.com/delphi2007/archive/2008/10/20/1314914.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值