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;