在数据库中设置CPID,CPGG两个字段为唯一字段
在ClientDataSet的UpdateError事件中处理
如果不行的化建两个ClientDataSet
在与DBGrid关联的OnPostBefore中Locate另一个ClientDataSet
如果找到就Abort

解决方案 »

  1.   

    处理dbgrid.datasource.dataset.onbeforepost事件即可,
    在数据库中查找并处理。
      

  2.   

    将CPID,CPGG设成primary key(主关键字),那么当你向数据库中写数据时,就会触发错误,此时你可以用try   except   end处理
      

  3.   

    在beforepost处理
    found:=odstpor.SearchRecord('receiver;line',VarArrayOf([odstporRECEIVER.Text,strtoint(odstporLINE.Text)]),[srFromBeginning]);
      if found then
        begin
          application.MessageBox('¸Ã¼Í¼ÒÑ´æÔÚ£¬ÇëÖØÐÂÊäÈ룡','Ìáʾ',mb_ok+mb_iconinformation);
          dxdbgrid1.SetFocus;
          abort;
        end;参考一下。
      

  4.   

    可能我问题没有表达清楚
    我使用ClientDataSet就是想界面,后台数据分开
    因此,能不能在界面数据源建主键,
    这个主键这么建,
    目的是我界面发现有这样的数据存在时是不调用数据组件与
    数据库交互的
      

  5.   

    使用Locate会很慢的.
    最好还是在应用逻辑端处理错误,返回给客户端再处理
      

  6.   

    呵呵,突然想到一种方法.使用临时表.
    您可以在本地建立一个临时表,为临时表的某一个字段建立一个主键.把输入的数据都存往临时表里面.只需在本地判断就够了.
    ================Try====================
      

  7.   

    呵呵,突然想到一种方法.使用临时表.
    您可以在本地建立一个临时表,为临时表的某一个字段建立一个主键.把输入的数据都存往临时表里面.只需在本地判断就够了.
    ================Try====================
      

  8.   

    其实你在数据源的前台,在每次与后台数据源的数据进行检测时,进行关键字段进行比较,从而可以判断记录是否存在相同的记录。不知道这样可不可以呢?
    ================================================================CSDN 论坛助手 Ver 1.0 B0402提供下载。 改进了很多,功能完备!★  浏览帖子速度极快![建议系统使用ie5.5以上]。 ★  多种帖子实现界面。 
    ★  保存帖子到本地[html格式]★  监视您关注帖子的回复更新。
    ★  可以直接发贴、回复帖子★  采用XML接口,可以一次性显示4页帖子,同时支持自定义每次显示帖子数量。可以浏览历史记录! 
    ★  支持在线检测程序升级情况,可及时获得程序更新的信息。★★ 签名  ●  
         可以在您的每个帖子的后面自动加上一个自己设计的签名哟。Http://www.ChinaOK.net/csdn/csdn.zip
    Http://www.ChinaOK.net/csdn/csdn.rar
    Http://www.ChinaOK.net/csdn/csdn.exe    [自解压]
      

  9.   

    其实你在数据源的前台,在每次与后台数据源的数据进行检测时,进行关键字段进行比较,从而可以判断记录是否存在相同的记录。不知道这样可不可以呢?
    ================================================================CSDN 论坛助手 Ver 1.0 B0402提供下载。 改进了很多,功能完备!★  浏览帖子速度极快![建议系统使用ie5.5以上]。 ★  多种帖子实现界面。 
    ★  保存帖子到本地[html格式]★  监视您关注帖子的回复更新。
    ★  可以直接发贴、回复帖子★  采用XML接口,可以一次性显示4页帖子,同时支持自定义每次显示帖子数量。可以浏览历史记录! 
    ★  支持在线检测程序升级情况,可及时获得程序更新的信息。★★ 签名  ●  
         可以在您的每个帖子的后面自动加上一个自己设计的签名哟。Http://www.ChinaOK.net/csdn/csdn.zip
    Http://www.ChinaOK.net/csdn/csdn.rar
    Http://www.ChinaOK.net/csdn/csdn.exe    [自解压]
      

  10.   

    BeforePost 中写事件查询是两关键字段否有重复,如果有则提示出错。如果用户已经作了大量数据处理,而又有几条出错,这种方法就象自杀。
      

  11.   

    你可以设一个不能重复的字段,post前检查一下有没有相同的值就行了。
      

  12.   

    你可以设一个不能重复的字段,post前检查一下有没有相同的值就行了。
      

  13.   

    procedure Tform1.Button1Click(Sender: TObject);
    begin
    with  table1 do
    begin
    if ((spinedit1.text<>'') and (edit1.text<>'')) then
    begin
    //if locate('工号',vararrayof([spinedit1.text]),[lopartialkey]) then begin
    if locate('工号',vararrayof([spinedit1.text]),[lopartialkey]) then
    begin
    showmessage('此员工已存在!');
    exit;
    end;
    try
    append;
    Table1.Insert;
         fDBGrid1.DataSource.DataSet.FieldByName('工号').AsString:=spinedit1.text;
         .DBGrid1.DataSource.DataSet.FieldByName('姓名').AsString:=Edit1.text;
         DBGrid1.DataSource.DataSet.FieldByName('性别’).asstring:=combobox1.text;
         Table1.post;
    Showmessage('添加成功!');
    except
    begin
    active:=false;
    showmessage('工号必须是1000000~9999999');
    active:=true;
    exit
    end;
     end;
    end else showmessage('工号及姓名不能为空!');
    end;
    end;