事务管理(BTransaction)
与 BDE 不同,IBX 使用一个独立的组件 `IBX.IBDatabase.TIBTransaction` 来控制事务。这一强大的特性允许您将事务与数据库连接分开,从而利用 InterBase 的两阶段提交功能(跨多个连接的事务)和使用同一连接的多个并发事务。
使用 `TIBTransaction` 组件来处理事务上下文,这可能涉及一个或多个数据库连接。在大多数情况下,简单的一个数据库/一个事务模型就足够了。
设置事务的步骤
- 设置 IBDatabase 连接:
- 首先,按照之前的步骤设置 `TIBDatabase` 组件,以确保能够连接到数据库。
- 添加 IBTransaction 组件:
- 在表单或数据模块上拖放一个 `TIBTransaction` 组件。
- 配置 DefaultDatabase 属性:
- 将 `DefaultDatabase` 属性设置为您的 `TIBDatabase` 组件的名称。例如:
IBTransaction1->DefaultDatabase = IBDatabase1;
- 激活事务:
- 将 `Active` 属性设置为 `True`,以启动事务。例如:
IBTransaction1->Active = true;
示例代码
以下是一个简单的示例,展示如何在 C++Builder 中设置和使用 `TIBTransaction` 组件:
cpp
void __fastcall TWebModule1::WebModule1DefaultHandlerAction(TObject *Sender, TWebRequest *Request,
TWebResponse *Response, bool &Handled)
{
Response->ContentType = "text/html; charset=utf-8";
// 设置数据库连接
IBDatabase1->Params->Values["username"] = "sysdba";
IBDatabase1->Params->Values["password"] = "masterkey";
IBDatabase1->Connected = true;
// 启动事务
IBTransaction1->DefaultDatabase = IBDatabase1;
IBTransaction1->Active = true;
// 执行查询
IBQuery1->SQL->Text = "SELECT CREATIONDATE, CONTENT FROM MEMOLIST";
IBQuery1->Open();
// 初始化响应内容
String responseContent = "<html><head><title>Web Server Application</title></head><body>";
responseContent += "<h1>查询结果</h1><table border='1'><tr><th>创建日期</th><th>内容</th></tr>";
// 检查是否有数据
if (!IBQuery1->Eof()) {
while (!IBQuery1->Eof()) {
String creationDate = IBQuery1->Fields->FieldByName("CREATIONDATE")->AsString;
String content = IBQuery1->Fields->FieldByName("CONTENT")->AsString;
responseContent += "<tr><td>" + creationDate + "</td><td>" + content + "</td></tr>";
IBQuery1->Next();
}
} else {
responseContent += "<tr><td colspan='2'>没有找到数据</td></tr>";
}
responseContent += "</table></body></html>";
Response->Content = responseContent;
// 提交事务
IBTransaction1->Commit();
// 标记请求已处理
Handled = true;
// 关闭查询
IBQuery1->Close();
}
注意事项
- 事务控制 :在执行数据库操作之前,确保事务已激活。在操作完成后,您可以选择提交(
Commit
)或回滚(Rollback
)事务。 - 错误处理:在生产环境中,建议添加错误处理机制,以便在数据库操作失败时能够适当地回滚事务。
- 并发事务 :如果您的应用程序需要处理并发事务,确保为每个请求或操作创建单独的
TIBTransaction
实例,以避免线程间的干扰。
通过以上步骤,您可以有效地管理 InterBase 数据库的事务,确保数据的一致性和完整性。