ADO + SQL Server:为什么事务处理会影响_RecordsetPtr查询结果??

tiger波波 2021-05-19 01:39:46
大家好,我的代码大致如下:


void foo()
{
try
{
_variant_t affected = 0;
_RecordsetPtr recordset_ptr = NULL;
_ConnectionPtr connection_ptr = NULL;

recordset_ptr.CreateInstance(__uuidof(Recordset));
connection_ptr.CreateInstance(__uuidof(Connection));

// 打开链接
connection_ptr->open(...)

// 执行查询
connection_ptr->BeginTrans(); // 1

recordset_ptr = connection_ptr->Excute(_bstr_t("select * from table_foo"), &affected, adCmdText);

connection_ptr->CommitTrans(); // 2

VARIANT_BOOL res = recordset_ptr->BOF; // 3

...
}
catch(_com_error &e)
{
e.ErrorMessage();
}
}


现在的情况是:
如果加上语句1和2,即BeginTrans()和CommitTrans(),那么执行语句3:VARIANT_BOOL res = recordset_ptr->BOF时
直接跳到异常里:灾难性故障。
如果注释掉语句1和2,即BeginTrans()和CommitTrans(),那么一切正常。

请问大家这是怎么回事?什么原理??
...全文
405 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
TOP3098 2021-05-27
  • 打赏
  • 举报
回复
CommitTrans应该是最后执行
tiger波波 2021-05-27
  • 打赏
  • 举报
回复
引用 6 楼 叶恭介1989 的回复:
VARIANT_BOOL res = recordset_ptr->BOF;这句放在connection_ptr->CommitTrans();上一行,会出问题吗?
没用,把3移过去,后边还有别的语句,一样会出错,也不能把后边的所有语句都弄过去。并且这样做没啥道理,CommitTrans不执行,下边的数据集应该没有东西。
叶恭介叶恭介 2021-05-26
  • 打赏
  • 举报
回复
VARIANT_BOOL res = recordset_ptr->BOF;这句放在connection_ptr->CommitTrans();上一行,会出问题吗?
tiger波波 2021-05-26
  • 打赏
  • 举报
回复
引用 4 楼 TOP3098 的回复:
2、3位置互换呢
没用,把3移过去,后边还有别的语句,一样会出错,也不能把后边的所有语句都弄过去。并且这样做没啥道理,CommitTrans不执行,下边的数据集应该没有东西。
TOP3098 2021-05-25
  • 打赏
  • 举报
回复
2、3位置互换呢
赵4老师 2021-05-20
  • 打赏
  • 举报
回复
我都是将事务放在SQL的存储过程里面。

4,011

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 数据库
社区管理员
  • 数据库
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧