起步软件技术论坛-X3

 找回密码
 立即注册
搜索
查看: 178|回复: 4

【结贴】事务提交的问题,急,在线等**

[复制链接]
发表于 2007-12-5 10:22:18 | 显示全部楼层 |阅读模式
var
   H:TTransactionHandle;

   query3.Connection:=query2.Connection;
   query3.Connection.Transaction:=query2.Connection.Transaction;
   H:=query2.Connection.Transaction.Start(true);

   try
      ......
      query2.Connection.Transaction.Commit(H);
      query3.Connection.Transaction.Commit(H);
   except
            query2.Connection.Transaction.Rollback(H);
            query2.Connection.Transaction.Rollback(H);
   end;

总之大概意思就是想让query3与query2在同一个事务中提交、回滚,我写的肯定是不对,正确的写法该怎么写呢?谢谢大家啦
回复

使用道具 举报

发表于 2007-12-5 10:28:23 | 显示全部楼层
回复 支持 反对

使用道具 举报

发表于 2007-12-5 11:01:18 | 显示全部楼层
var
   H:TTransactionHandle;

   query3.Connection:=query2.Connection;
   H:=query2.Connection.Transaction.Start(False);
   try
      ......
      query2.Connection.Transaction.Commit(H);
   except
            query2.Connection.Transaction.Rollback(H);
      raise;
   end;
回复 支持 反对

使用道具 举报

 楼主| 发表于 2007-12-5 12:59:12 | 显示全部楼层
谢谢啦!
回复 支持 反对

使用道具 举报

发表于 2007-12-5 13:25:31 | 显示全部楼层
3楼给的方法没有注意,应该尽量用非立即事务,我已经改了3楼的贴子了
有关非立即事务,请参考2楼给的链接
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Justep Inc.

GMT+8, 2025-7-1 11:20 , Processed in 0.050260 second(s), 15 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表