1.软文推荐

2.软文推荐

3.软文推荐

说到事务一定会提到ACID,所谓事务的原子性,一致性,隔离性和持久性。对于一个数据库而言,通常通过并发控制和故障恢复手段来保证事务在正常和异常情况下的ACID特性。sqlite也不例外,虽然简单,依然有自己的并发控制和故障恢复机制。

事务的属性
1.事务(Transaction)具有以下四个标准属性,通常根据首字母缩写为 ACID:
2.原子性(Atomicity):确保工作单位内的所有操作都成功完成,否则,事务会在出现故障时终止,之前的操作也会回滚到以前的状态。
3.一致性(Consistency):确保数据库在成功提交的事务上正确地改变状态。
4.隔离性(Isolation):使事务操作相互独立和透明。
5.持久性(Durability):确保已提交事务的结果或效果在系统发生故障的情况下仍然存在。
事务控制

使用下面的命令来控制事务:

1.BEGIN TRANSACTION:开始事务处理。
2.COMMIT:保存更改,或者可以使用 END TRANSACTION 命令。
3.ROLLBACK:回滚所做的更改。

事务控制命令只与 DML 命令 INSERT、UPDATE 和 DELETE 一起使用。他们不能在创建表或删除表时使用,因为这些操作在数据库中是自动提交的。

BEGIN TRANSACTION 命令

事务(Transaction)可以使用 BEGIN TRANSACTION 命令或简单的 BEGIN 命令来启动。此类事务通常会持续执行下去,直到遇到下一个 COMMIT 或 ROLLBACK 命令。不过在数据库关闭或发生错误时,事务处理也会回滚。以下是启动一个事务的简单语法:

BEGIN;
or
BEGIN TRANSACTION;
COMMIT 命令

COMMIT 命令是用于把事务调用的更改保存到数据库中的事务命令。 COMMIT 命令把自上次 COMMIT 或 ROLLBACK 命令以来的所有事务保存到数据库。 COMMIT 命令的语法如下:

COMMIT;
or
END TRANSACTION;
ROLLBACK 命令

ROLLBACK 命令是用于撤消尚未保存到数据库的事务的事务命令。

ROLLBACK 命令只能用于撤销自上次发出 COMMIT 或 ROLLBACK 命令以来的事务。

ROLLBACK 命令的语法如下:

ROLLBACK;
实例

假设 COMPANY 表有以下记录:

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

现在,让我们开始一个事务,并从表中删除 age = 25 的记录,最后,我们使用 ROLLBACK 命令撤消所有的更改。

sqlite> BEGIN;
sqlite> DELETE FROM COMPANY WHERE AGE = 25;
sqlite> ROLLBACK;

检查 COMPANY 表,仍然有以下记录:

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

现在,让我们开始另一个事务,从表中删除 age = 25 的记录,最后我们使用 COMMIT 命令提交所有的更改。

sqlite> BEGIN;
sqlite> DELETE FROM COMPANY WHERE AGE = 25;
sqlite> COMMIT;

检查 COMPANY 表,有以下记录:

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
3           Teddy       23          Norway      20000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

本文来源:www.lxlinux.net/5491.html,若引用不当,请联系修改。

相关文章 8

1

【便宜】20元/月 512M内存 20G硬盘 1Gbps不限流量 BGP优化线路 洛杉矶 雨云IDC 30秒前

雨云IDC是一家成立于2018年的国内技术型IDC商家,系广州润雨科技有限公司旗下品牌,目前已经积累了一定的人气的信誉,采用自主研发的财...

2

DigitalVirt:新上洛杉矶 4837线路VPS,1核1G 20GSSD,200-500Mbps@1TB流量 3分钟前

DigitalVirt,国人商家,主要提供KVM VPS,数据中心有洛杉矶、香港等,主打洛杉矶三网9929线路的KVM VPS,国内速度优秀, vCPU为独享 ,NVMe硬盘...

3

青岛域名快速备案的公司(新网域名自助管理平台) 5分钟前

广州合优网络科技有限公司 让您的网站走在互联网的前端!以最佳的用户体验,让客户随时随地找到您!所谓响应式网页建设,是指可以自...

4

Docker 容器测试全探索 7分钟前

导读 我们在构建好Docker并利用多套容器组合应用程序后,我们改怎样测试择机的Docker容器,下面分享几方案供大家参考。 为了解决上述难题...

5

智简魔方DCIM系统如何使用API对接魔方财务系统(智简魔方对接) 9分钟前

智简魔方dcim系统如何使用API对接魔方财务系统? 智简魔方,是重庆顺戴网络科技有限公司 旗下品牌,专注 IDC 基础业务管理软件及 IDC行业...

6

宝塔面板屏蔽特定IP访问的两种简单方法(宝塔面板关闭) 11分钟前

宝塔面板是一款简单易用的服务器管理软件,支持Windows和Linux两种操作系统,我们可以通过Web端轻松管理服务器。网站运行过程中,可能会...

7

krypt旗下iON周末优惠码发送!美国CN2,1核2G方案终生五折,5美元/月 14分钟前

iON,Krypt旗下新创办的VPS销售品牌,最近比较热门的一个商家,优势是1998年创办的老品牌,跑路绝对是不可能的,产品质量应该也是小商家...

8

小榄镇做网站多少钱(小榄网络公司) 15分钟前

广州合优网络科技有限公司 让您的网站走在互联网的前端!以最佳的用户体验,让客户随时随地找到您!所谓响应式网页建设,是指可以自...