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(),那么一切正常。

请问大家这是怎么回事?什么原理??
...全文
375 6 打赏 收藏 举报
写回复
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
TOP3098 2021-05-27
CommitTrans应该是最后执行
  • 打赏
  • 举报
回复
tiger波波 2021-05-27
引用 6 楼 叶恭介1989 的回复:
VARIANT_BOOL res = recordset_ptr->BOF;这句放在connection_ptr->CommitTrans();上一行,会出问题吗?
没用,把3移过去,后边还有别的语句,一样会出错,也不能把后边的所有语句都弄过去。并且这样做没啥道理,CommitTrans不执行,下边的数据集应该没有东西。
  • 打赏
  • 举报
回复
叶恭介1989 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的存储过程里面。
  • 打赏
  • 举报
回复
相关推荐
发帖
数据库
加入

3975

社区成员

VC/MFC 数据库
社区管理员
  • 数据库
申请成为版主
帖子事件
创建了帖子
2021-05-19 01:39
社区公告
暂无公告