Delphi 中 FireDAC 数据库连接(管理事务)

news2024/11/27 11:56:33

参见:Delphi 中 FireDAC 数据库连接(总览)

描述了如何使用FireDAC来管理DBMS事务。FireDAC提供TFDConnection和TFDTransaction组件来帮助你处理数据库事务。

一、概述

默认情况下,FireDAC应用程序在自动提交模式下工作,当需要时,FireDAC会自动启动一个事务,并在命令执行成功时提交,或在失败时回滚。自动提交是由TFDTxOptions.AutoCommit属性控制的。自动提交模式对应用程序来说很简单,但它:

  1. 减慢了对数据库的多次更新。

  1. 不允许你在一个事务中执行更多的数据库操作。

  1. 不能在一个时间内延长。

另外,应用程序可以使用显式事务控制。为此,使用TFDConnection方法StartTransaction, Commit, Rollback。另一个选择是使用TFDTransaction组件。

注意:在FireDAC中,TFDTransaction组件的使用是可选的。

FireDAC提供了Isolation, ReadOnly, Params属性,允许你控制事务模式。它们同时适用于自动提交和显式事务。并非所有的模式都被DBMS支持,例如只读模式,因为FireDAC使用了一个限制性较小的模式。注意,所有的设置将只应用于下一个事务。

使用显式事务的标准代码如下:

FDConnection1.StartTransaction;
try
  FDQuery1.ExecSQL;
  ....
  FDQuery1.ExecSQL;
  FDConnection1.Commit;
except
  FDConnection1.Rollback;
  raise;
end;

TFDTransaction组件将事务控制功能包装成一个组件。实际上,它提供了与TFDConnection相同的事务功能,但允许你通过将命令和数据集链接到一个特定的事务对象来分组。起初,这指的是对多个活动事务的支持,也就是Interbase和Firebird的服务器功能。

TFDTxOptions.Params可以用来指定DBMS特定的事务属性。目前,只有Firebird / InterBase驱动支持这种属性。每个属性必须在一个单独的行中指定。它与isc_tpb_<属性名称>事务参数相对应。

二、嵌套事务

虽然没有一个支持的数据库管理系统支持嵌套事务,但是FireDAC使用保存点来模拟它们。这意味着嵌套的StartTransaction调用并不启动一个新的事务,也不引发一个异常,而是放置一个保存点。如果一个DBMS不支持保存点,那么就会引发 "不支持能力 "的异常。

要禁用嵌套事务,将TFDTxOptions.EnableNested设置为False。然后,嵌套的StartTransaction调用会引发一个异常。

相应的Commit调用会释放一个保存点,Rollback会回滚到一个保存点。比如说:

// start new transaction
FDConnection1.StartTransaction;
try
  FDQuery1.ExecSQL;
  ....

  // set savepoint
  FDConnection1.StartTransaction;
  try
    FDQuery1.ExecSQL;
    ....

    // release savepoint
    FDConnection1.Commit;
  except
    // rollback to savepoint
    FDConnection1.Rollback;
    raise;
  end;

  // commit transaction
  FDConnection1.Commit;

except
  // rollback transaction
  FDConnection1.Rollback;
  raise;
end;
注意:一个嵌套交易(事务)使用最上层交易(事务)的设置。

三、连续交易(事务)

CommitRetaining和RollbackRetaining方法与Commit和Rollback方法类似,但它们不会完成事务。因此,在这些调用之后,它仍然处于活动状态。Firebird / InterBase服务器在DBMS核心层面上支持这个功能。对于所有其他的数据库管理系统,这个功能是用Commit / Rollback和StartTransaction调用来模拟的。

四、多个有效交易(事务)

Firebird和InterBase在DBMS核心层支持多个活动事务。这意味着一些命令可以在一个事务上下文中执行,另一些在第二个事务上下文中执行,以此类推。为了支持这一特性,FireDAC提供了TFDTransaction组件。它的单一实例允许你在任何时候处理单一事务。

TFDCustomConnection属性可以用来设置默认的事务对象。

  • Transaction - 所有命令的默认交易对象。

  • UpdateTransaction - 所有更新命令的默认事务对象,用于发布FireDAC数据集的更新。请注意,UpdateTransaction不会被使用,例如,对于明确指定给TFDQuery组件的UPDATE查询。

TFDCustomQuery和其他组件有类似的属性。

  • Transaction - 用于执行SQL查询的显式事务对象。

  • UpdateTransaction - 明确的事务对象,用于发布数据集的更新。

一般来说,为Firebird / InterBase应用程序设置事务对象的最佳方式如下:

UpdateTransaction: TFDTransaction;
ReadTransaction: TFDTransaction;
...
// setup transaction for updating commands: read_committed, rec_version, nowait
UpdateTransaction.Connection := FDConnection1;
FDConnection1.UpdateOptions.LockWait := False;
UpdateTransaction.Options.ReadOnly := False;
UpdateTransaction.Options.Isolation := xiReadCommitted;
...
ReadTransaction.Connection := FDConnection1;
ReadTransaction.Options.ReadOnly := True;
ReadTransaction.Options.Isolation := xiReadCommitted;
...
SelectQuery.Transaction := ReadTransaction;
SelectQuery.UpdateTransaction := UpdateTransaction;
注意:你可以为其他数据库管理系统使用一个以上的TFDTransaction。然后,所有TFDTransaction组件共享同一个事务。

五、事务和游标

DBMS将一个开放的游标与交易上下文相关联,在那里它被打开。当事务完成后,DBMS可能会使活动游标失效。具体的行为取决于DBMS。

DBMS

Action

Microsoft Access

在StartTransaction / Commit / Rollback中使游标无效。

Firebird

在提交/回滚时使游标无效。

Informix

<nothing>

InterBase

在提交/回滚时使游标无效。

IBM DB2

在回滚时使游标无效。

MySQL

在StartTransaction / Commit / Rollback中使游标无效。

Oracle

<nothing>

PostgreSQL

在提交/回滚时使游标无效。

SQLite

在回滚时使游标无效。

SQL Anywhere

<nothing>

SQL Server

在StartTransaction / Commit / Rollback中使游标无效。

Teradata Database

<nothing>

当FireDAC发现一个导致游标失效的事务控制命令时,它会执行FetchOptions.AutoFetchAll指定的动作,并释放游标。

注意:Firebird / InterBase服务器在事务完成后会使准备好的语句失效。因此,自动提交模式可能导致这些数据库管理系统的性能下降。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/384263.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Cloud Alibaba全家桶(四)——微服务调用组件Feign

前言 本文小新为大家带来 微服务调用组件Feign 的相关知识&#xff0c;具体内容包含什么是Feign&#xff0c;Spring Cloud Alibaba快速整合OpenFeign&#xff0c;Spring Cloud Feign的自定义配置及使用&#xff08;包括&#xff1a;日志配置、契约配置、自定义拦截器实现认证逻…

五方面提高销售流程管理的CRM系统

销售充满了不确定性&#xff0c;面对不同的客户&#xff0c;销售人员需要采用不同的销售策略。也正因为这种不确定性&#xff0c;规范的销售流程对企业尤为重要&#xff0c;它会让销售工作更加有效&#xff0c;快速地实现成交。下面小编给您推荐个不错的CRM销售流程管理系统。 …

BQ25071QWDQCRQ1示意图ISO6721BQDRQ1引脚配置ISO7330CQDWRQ1数字隔离器

1、BQ25071QWDQCRQ1应用程序示意图BQ25071 1A 单输入、单节线性电池充电器是一款高度集成的线性 LiFePO4 电池充电器&#xff0c;适用于空间受限的便携式应用。它接受来自 USB 端口或交流适配器的电力&#xff0c;为单节 LiFePO4 电池提供高达 1A 的充电电流。该器件具有单个电…

【DaVinci Developer专题】-45-自动生成SWC中所有Runnable对应的C文件

点击返回「Autosar从入门到精通-实战篇」总目录 案例背景(共5页精讲): 在DaVinci Developer中,以Test_A_SWC的Runnable为例,见图0-1。我们现在尝试自动生成一个包含Test_A_SWC_Init和Test_A_SWC_Main函数原型(也是适用于 C/S Port Serve Runnable)的C文件。 图0-1 目…

详解旨在提升EVM底层性能的兼容公链Monad

EVM带来的繁荣2020年以太坊链上DeFi的蓬勃发展使得EVM成为关注焦点&#xff0c;大部分DeFi项目都开始基于以太坊公链&#xff0c;这也使得EVM成为行业的标杆&#xff0c;不少链都加入了EVM大军&#xff0c;比如polygon、BSC、fantom等等&#xff0c;而EVM也使得链上生态进一步繁…

【算法笔记】队列与优先队列

队列与优先队列 1.队列的概念 只允许在一端插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff1b;进行插入操作的一端称为队尾&#xff08;入队列&#xff09;&#xff0c;进行删除操作的一端称为队头&#xff08;出队列&#xff09;&#xff1b; 队列…

离散事件动态系统

文章目录离散事件动态系统ppt离散事件系统建模离散事件动态系统的基本组成元素离散事件动态系统仿真具体建模petri建模实例离散事件动态系统 ppt ppt 仿真建模步骤 离散事件系统建模 from&#xff1a;离散事件系统建模 离散事件动态系统的基本组成元素 &#xff08;1&am…

腾讯云服务器CVM和轻量应用服务器区别对比

腾讯云新推出的轻量应用服务器Lighthouse和原来的CVM云服务器有什么区别&#xff1f;轻量应用服务器Lighthouse是一种易于使用和管理、适合承载轻量级业务负载的云服务器&#xff0c;主要用于Web网站应用&#xff0c;轻量服务器使用及后期运维更加简单方便&#xff1b;云服务器…

TypeError: Axes3D.view_init() got an unexpected keyword argument ‘roll‘——版本问题

解决办法 删除roll关键字参数。 掉坑过程 今天在学习matplotlib绘制3D图形时&#xff0c;使用的是matplotlib官网提供的例子Plot 2D data on 3D plot 敲好代码后&#xff0c;运行时报错TypeError: Axes3D.view_init() got an unexpected keyword argument ‘roll’ 看来官…

k8s学习之路 | Day18 Pod 基础

文章目录Pod 基础认知什么是 PodPod 的示例 yamlPod 的形式Pod 的多容器协同Pod 的生命周期容器的类型应用容器初始化容器临时容器静态 Pod什么是静态 Pod静态 Pod 位置Pod 探针机制探针类型Probe 配置项探针案例Pod 基础认知 什么是 Pod https://kubernetes.io/zh-cn/docs/c…

黑马程序员Java教程学习笔记(四)

学习视频&#xff1a;https://www.bilibili.com/video/BV1Cv411372m 如侵权&#xff0c;请私信联系本人删除 文章目录黑马程序员Java教程学习笔记&#xff08;四&#xff09;static&#xff1a;修饰成员变量、内存机制static&#xff1a;修饰成员方法、内存机制static访问注意事…

【Vue学习】Vue原理—虚拟DOM和diff算法

1. 虚拟DOM 1.1 虚拟DOM介绍 主流前端框架(Vue、React)的主要思想是数据驱动视图&#xff0c;以避免不必要DOM操作&#xff0c;从而提高Web应用程序的性能。如何高效的操作DOM&#xff0c;就需要使用虚拟DOM(Virtual DOM, vdom)技术。在Vue的实现中&#xff0c;虚拟DOM是以Ja…

信息收集工具使用详解

要求&#xff1a;熟练掌握域名收集、子域名、IP地址收集的各种工具的使用&#xff0c;结果写入实验报告 警示&#xff1a;遵纪守法 工具&#xff1a;kail 信息收集 信息收集又称 网络踩点(footprinting)&#xff0c;攻击者通过各种途径对要攻击的目标进行有计划和有步骤的信息…

除了ChatGPT,这20款AI神器同样值得你使用

2022年是AI技术大发展的一年&#xff0c;特别是ChatGPT的很空出世&#xff0c;让AI工具迎来大爆发&#xff0c;今天就给大家整理出20款免费且实用的AI工具推荐&#xff0c;无论是做设计还是日常学习工作都能用得到。2023年已经开始&#xff0c;让这些AI工具帮你提升生产效率&am…

Docker SYS_ADMIN 权限容器逃逸

1.漏洞原理Docker容器不同于虚拟机&#xff0c;它共享宿主机操作系统内核。宿主机和容器之间通过内核命名空间&#xff08;namespaces&#xff09;、内核Capabilities、CGroups&#xff08;control groups&#xff09;等技术进行隔离。若启动docker容器时给主机一个--cap-addSY…

【el】表格

一、用法1、动态表格后端返回的值&#xff1a;第一个数组是表头&#xff0c;其余是内容<el-tableref"tableHeight":data"tableColumns":height"tableHeight"borderstyle"width: 100%; margin-top: 1%"row-click"rowclick"…

14、字符串处理函数

目录 一、字符串复制 二、字符串连接 三、字符串比较 四、字符串大小写转换 五、获得字符串长度 一、字符串复制 在字符串处理函数中包含strcpy函数&#xff0c;该函数可用于复制特定长度的字符串到另一个字符串中。其语法格式如下&#xff1a; 功能&#xff1a;把源字符…

张驰咨询:用六西格玛方法降低锂电池内部短路缺陷

锂电池作为现代电子设备中最常用的电池类型之一&#xff0c;由于其高能量密度和长寿命等优点&#xff0c;已经广泛应用于手机、笔记本电脑、电动车等领域。然而&#xff0c;在锂电池制造过程中&#xff0c;由于材料、工艺、设备等多种因素的影响&#xff0c;会产生内部短路的问…

基于麻雀算法改进的SVM电器启动识别,基于麻雀算法优化SVM分类预测

目录 摘要 背影 Eggholder测试函数 MATALB编程 测试函数代码 麻雀算法原理 麻雀算法主要参数 麻雀算法流程图 麻雀算法优化测试函数代码 基于麻雀算法改进的SVM电器启动识别 matlab编程实现 效果图 结果分析 展望 摘要 麻雀算法理论&#xff0c;SSA-SVM,电器启动识别&#x…

Android开发之简单控件

文章目录一 文本显示1.1 文本设置的两种方式1.2 常见字号单位类型2.2 设置文本的颜色三 视图基础3.1 设置视图的宽高3.2 设置视图的间距3.3 设置视图的对齐方式四常用布局4.1 线性布局LinearLayout4.2 相对布局RelativeLayout4.3 网格布局GridLayout4.4 滚动视图ScrollView五 按…