Delphi ADOQuery处理多条SQL语句

Delphi(Pascal) code 
var 
  sqlStr:String;
begin
  sqlStr:= ‘ begin ‘
  sqlStr:= sqlStr+ ‘update table1 set col1 = ‘‘test‘‘ where 1=2;‘;
  sqlStr:= sqlStr+ ‘update table1 set col1 = ‘‘test2‘‘ where 1=2;‘;
  sqlStr:= sqlStr+ ‘ end ‘;

adoquery1.Close; 
  adoquery1.SQL.Clear; 
  adoquery1.SQL.Add(sqlStr); 
  adoquery1.ExecSQL;
end;

把sql语句用begin...end包起來,再提交給DB处理,就OK了!

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;

用adoquery取指定字段所有值问题
我要在在DBComboBox里显示出来啊
while   not   adoquery1.Eof   do   
  begin   
      ComboBox1.Items.Add(adoquery1.fieldbyname(‘id‘).asstring);   //id改为你要指定的字段   
      adoquery1.Next;   
  end;
在DBComboBox里显示出来啊
如果是DBComboBox   
  procedure   TForm1.FormCreate(Sender:   TObject);   
  begin   
      adoquery1.SQL.Add(‘select   *   from   test);   
      adoquery1.Open;   
      DBComboBox1.DataField:=‘id‘;   
      while   not   adoquery1.Eof   do   
      begin   
          DBComboBox1.Items.Add(adoquery1.fieldbyname(DBComboBox1.DataField).AsString);   
          adoquery1.Next;   
      end;   
end;

xxx.sql.text := ‘insert into t_log3(name,czsj,czlog)values(‘‘‘+a +‘‘‘,‘‘‘+ b+‘‘‘,‘‘‘+c+‘‘‘)‘;

xxx.sql.text := ‘insert into t_log3(name,czsj,czlog)values(:a1,:b1,:c1)‘;
xxx.parameters.parambyname(‘a1‘).values := a;
xxx.parameters.parambyname(‘b1‘).values := b;
xxx.parameters.parambyname(‘c1‘).values := c;

时间: 2024-07-30 15:54:32

Delphi ADOQuery处理多条SQL语句的相关文章

用一条SQL语句查出每门课都大于80分的学生的姓名

用一条sql语句查询出所有课程都大于80分的学生名单: name cource score 张三 语文 81 张三 数学 75 李四 语文 76 李四 数学 90 王五 语文 81 王五 数学 100 王五 英语 90 1 SET FOREIGN_KEY_CHECKS=0; 2 3 -- ---------------------------- 4 -- Table structure for grade 5 -- ---------------------------- 6 DROP TABL

mysql(1)—— 详解一条sql语句的执行过程

SQL是一套标准,全称结构化查询语言,是用来完成和数据库之间的通信的编程语言,SQL语言是脚本语言,直接运行在数据库上.同时,SQL语句与数据在数据库上的存储方式无关,只是不同的数据库对于同一条SQL语句的底层实现不同罢了,但结果相同.这有点类似于java中接口的作用,一个接口可以有不同的实现类,不同的实现类对于接口中方法的实现方式可以不同,结果可以相同.这里SQL语言的作用就类似于java中的接口,数据库就类似于java中接口的实现类,SQL语句就类似于java接口中的方法.不同的是java中

详解一条sql语句的执行过程

SQL是一套标准,全称结构化查询语言,是用来完成和数据库之间的通信的编程语言,SQL语言是脚本语言,直接运行在数据库上.同时,SQL语句与数据在数据库上的存储方式无关,只是不同的数据库对于同一条SQL语句的底层实现不同罢了,但结果相同.这有点类似于java中接口的作用,一个接口可以有不同的实现类,不同的实现类对于接口中方法的实现方式可以不同,结果可以相同.这里SQL语言的作用就类似于java中的接口,数据库就类似于java中接口的实现类,SQL语句就类似于java接口中的方法.不同的是java中

数据库 将多条SQL语句查询的内容整合成为一个元组

1.情景再现 分类信息 住户 租户 快递 亲友访问 花苑 138 25 44 89 新城 34 150 78 34 以上的一张表中,假如要分别在两个住宅小区统计各类进出的人数,进出的类型可以分为是住户,租户,快递以及亲友访问四个类型. 但是实际的表设计中,住户以及租户是属于这个小区,可以直接统计出来,但是快递以及亲友访问则需要从进出记录查找. 换言之,就是表中的每个元组的数据是从多个表中查出来的,同时可能是用四条sql语句中查询出来的.使用如下表达: ①: select t.name as co

MyBatis插件及示例----打印每条SQL语句及其执行时间

Plugins 摘一段来自MyBatis官方文档的文字. MyBatis允许你在某一点拦截已映射语句执行的调用.默认情况下,MyBatis允许使用插件来拦截方法调用 Executor(update.query.flushStatements.commint.rollback.getTransaction.close.isClosed) ParameterHandler(getParameterObject.setParameters) ResultSetHandler(handleResultS

用一条SQL语句取出第 m 条到第 n 条记录的方法

原文:用一条SQL语句取出第 m 条到第 n 条记录的方法   --从Table 表中取出第 m 条到第 n 条的记录:(Not In 版本) SELECT TOP n-m+1 * FROM Table WHERE (id NOT IN (SELECT TOP m-1 id FROM Table )) --从TABLE表中取出第m到n条记录 (Exists版本) SELECT TOP n-m+1 * FROM TABLE AS a WHERE Not Exists (Select * From 

关于使用一条SQL语句 找出同时符合多个tag条件的记录集合算法

表结构 Tag Table:{tag_id, tag_name}  #标签表 News Table:{news_id, title,......}  #新闻表 NewsTags Table:{tag_id, news_id}  #新闻的标签关系表 解释: 一条新闻,有多个tag标签,例如: 新闻a{Tag1,Tag2, Tag3, Tag4} 新闻b{Tag1,Tag6, Tag7, Tag8} 新闻c{Tag8,Tag9, Tag10, Tag1} 新闻...{Tag..., .....} 搜

一条sql语句具体执行过程

客户端发送一条查询语句给服务器 服务器先检查缓存,如果有就直接返回数据,否则进入下一个阶段. 服务器进行sql解析,预处理,再由优化器生成对应的执行计划 根据执行计划,调用API接口来执行查询 返回结果给客户端,并缓存 一条sql语句具体执行过程,布布扣,bubuko.com

执行多条SQL语句,实现数据库事务。(Oracle数据库)

/// <summary> /// 执行多条SQL语句,实现数据库事务. /// </summary> /// <param name="SQLStringList">(key为sql语句,value是该语句的OracleParameter[])</param> /// <returns></returns> public static bool ExecuteSqlTran(Dictionary<strin