zoukankan      html  css  js  c++  java
  • ADOQuery的批处理方式

    比如在一个窗体里有一个“取消”和“确定”按钮,“取消”按钮批次取消所有修改,“确定”按钮批次提交:
    1.设置QryDef(数据集)的LockType为ltBatchOptimistic,CursorType为ctStatic,CursorLocation为clUseClient
    2.“确定”按钮的单击事件为:
      if QryDef.Connection.InTransaction then
      begin
        try
          QryDef.UpdateBatch();
          QryDef.Connection.CommitTrans;
        except
          QryDef.Connection.RollbackTrans;
        end;
      end;
    3.“取消”按钮的单击事件为:
      QryDef1.CancelBatch;
    4.初始插入数据:
      Qry.LoadFromFile(ExtractFilePath(Application.ExeName) + 'ClassifyDefine');
      {$IFDEF Test}codesite.SendMsg('3'); {$ENDIF}
      while not Qry.Eof do
      begin
        QryDef.Append;
        QryDef.FieldByName('name').AsString := Qry.FieldByName('name').AsString;
        if not Qry.FieldByName('Money1').IsNull then
       QryDef.FieldByName('Money1').AsCurrency := Qry.FieldByName('Money1').AsCurrency;
        if not Qry.FieldByName('Money2').IsNull then
       QryDef.FieldByName('Money2').AsCurrency := Qry.FieldByName('Money2').AsCurrency;
        QryDef.Post;
        Qry.Next;
      end;
      QryDef.UpdateBatch(); 

    5.批处理方式其它实例:

    procedure TForm1.Button1Click(Sender: TObject);
    begin
    adoconnection1.begintrans;
    try
    adoquery.close;
    adoquery.sql.clear;
    adoquery.sql.add(insert 语句);
    adoquery.execsql;
    如果还有insert 语句则:
    adoquery.close;
    adoquery.sql.clear;
    adoquery.sql.add(insert 语句);
    adoquery.execsql;直到所有insert 语句完成.
    adoconnection1.committrans;
    except
    adoconnection1.rollbacktrans;
    end;
    end;

  • 相关阅读:
    python写的百度贴吧相册下载
    C#的图片拼接
    删除目录下的所有".svn"文件
    centOS 6.5 yum升级 gcc4.8 然后又退回来4.4
    代理的分类简述特点
    GCC 特性整理
    纯C 实现 strpos substr strspilt str_trim
    编译putty 源码去掉 Are you sure you want to close this session? 提示
    OpenWrt tcpdump 抓包
    安卓 打飞机 app 开发 第一篇
  • 原文地址:https://www.cnblogs.com/djcsch2001/p/1783269.html
Copyright © 2011-2022 走看看