mysql 事务

mysql 事务 原文链接http://blog.csdn.net/w_l_j/article/details/6783319

事务

在MySQL环境中,事务由作为一个单元的一个或多个SQL语句组成。这个单元中的每一个SQL语句是互相依赖的,而且单元作为一个整体式不可分割的。如果单元的一个语句不能完成,整个单元就会回滚(撤销),所有影响到的数据将返回到事务开始以前的状态。因而,只有事务中的所有语句都成功地执行才能说这个事务被成功地执行。

事务和ACID属性

术语”ACID”是一个简称,每一个事务的处理必须满足ACID原则,即原子性(A)、一致性(C)、隔离性(I)和持久性(D)。

(1)原子性

原子性意味着每个事务都必须被认为是一个不可分割的单元

(2)一致性

不管事务是完全成功完成还是中途失败,当事务使系统处于一致的状态时存在一致性

(3)隔离性

隔离性是指每个事物在它自己的空间发生,和其他发生在系统中的事务隔离,而且事务的结果只有在它完全被执行时才能看到

(4)持久性

持久性是指即使系统崩溃,一个提交的事务仍然存在

事务处理

  在sql中,当一个会话开始时,系统变量AUTOCOMMIT值为1,既自动提交功能是打开的,当用户执行一条sql语句结束后该语句对数据库的修改就立即被提交成为持久性修改保存到磁盘中,一个事务就结束了。

关闭自动提交,才能由多条SQL语句组成,使用如下语句:

SET@@AUTOCOMMIT=0;

执行此语句后必须明确地指示每个事务的终止,事务中的SQL语句对数据库所作的修改才能成为持久化修改。

delect from  xs  where  学号=’081101’;

select *  from  xs;

1、开始事务   语法格式

start transaction  |  begin work

一条begin  work语句可以用来代替start transaction 语句,但是start  transaction更常用

2、结束事务   语法格式

commit [work]  [and [no] chain] [[no]release]

可选的and  chain子句会在当前事务结束时,立即启动一个新事务,并且新事务与刚结束的事务有相同的隔离等级,release子句在终止了当前事务后,会让服务器断开与当前客户端的连接。包含no关键词可以抑制chain或commit完成

3、撤销事务

Rollback语句是撤销语句它撤销事务所做的修改,并结束当前这个事务          语法格式

Rollback [work] [and [no] chain]  [[no] release]

在前面的举例中,若在最后加上rollback  work,执行完这条语句后,前面的删除动作将被撤销,可以使用select语句查看该行数据是否还原。

4、回滚事务

除了撤销事务,用户还可以使用rollback  to语句是事务回滚到某个点,在这之前需要使用savepoint语句来设置一个保存点

savepoint语法格式如下:

savepoint identifier

其中identifier为保存点的名称

rollback to savepoint 语句会向已命名的保存点回滚一个事务。如果保存点被设置后,当前事务对数据进行更改,则这些更改会在回滚中被撤销。语法格式如下:

rollback [work] to savepoint identifier

当事务回滚到某个保存点后,在该保存点之后设置的保存点将被删除

事务隔离级

只有支持事务的存储引擎才可以定义一个隔离级。定义隔离级可以使用set transaction语句

语法格式:set [global | session] transaction  isolation level

serializable

 |repeatable  read

 |read committed

 |read uncommitted

(1)序列化:如果隔离级为序列化,用户之间通过一个接一个顺序地执行当前事务提供了事务之间最大限度的隔离。

(2)可重复读:在这一级上,事务不会被看成是一个序列。如果用户在同一个事务中执行同条select语句次数,结果总是相同的。

(3)提交读:readcommitted隔离级的安全性比repeatable read隔离级的安全性要差。在事务处理期间,如果其他事务修改了相应的表,那么同一个事务的多个select语句可能返回不同的结果

(4)未提交读:提供了事务之间最小限度的隔离。除了容易产生虚幻的读操作和不能重复的读操作外,处于这个隔离级得事务可以读到其他事务还没有提交的数据,如果这个事务使用其他事务不提交的变化作为计算的基础,然后那些未提交的变化被它们的父事务撤销,这就导致了大量的数据变化。

默认情况下,系统变量的值是基于每个会话设置的,但是可以通过set命令行添加global关键字修改该全局变量的值。

转载于:https://my.oschina.net/u/2563638/blog/709100

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
水资源是人类社会的宝贵财富,在生活、工农业生产中是不可缺少的。随着世界人口的增长及工农业生产的发展,需水量也在日益增长,水已经变得比以往任何时候都要珍贵。但是,由于人类的生产和生活,导致水体的污染,水质恶化,使有限的水资源更加紧张。长期以来,油类物质(石油类物质和动植物油)一直是水和土壤中的重要污染源。它不仅对人的身体健康带来极大危害,而且使水质恶化,严重破坏水体生态平衡。因此各国都加强了油类物质对水体和土壤的污染的治理。对于水中油含量的检测,我国处于落后阶段,与国际先进水平存在差距,所以难以满足当今技术水平的要求。为了取得具有代表性的正确数据,使分析数据具有与现代测试技术水平相应的准确性和先进性,不断提高分析成果的可比性和应用效果,检测的方法和仪器是非常重要的。只有保证了这两方面才能保证快速和准确地测量出水中油类污染物含量,以达到保护和治理水污染的目的。开展水中油污染检测方法、技术和检测设备的研究,是提高水污染检测的一条重要措施。通过本课题的研究,探索出一套适合我国国情的水质污染现场检测技术和检测设备,具有广泛的应用前景和科学研究价值。 本课题针对我国水体的油污染,探索一套检测油污染的可行方案和方法,利用非分散红外光度法技术,开发研制具有自主知识产权的适合国情的适于野外便携式的测油仪。利用此仪器,可以检测出被测水样中亚甲基、甲基物质和动植物油脂的污染物含量,为我国众多的环境检测站点监测水体的油污染状况提供依据。
### 内容概要 《计算机试卷1》是一份综合性的计算机基础和应用测试卷,涵盖了计算机硬件、软件、操作系统、网络、多媒体技术等多个领域的知识点。试卷包括单选题和操作应用两大类,单选题部分测试学生对计算机基础知识的掌握,操作应用部分则评估学生对计算机应用软件的实际操作能力。 ### 适用人群 本试卷适用于: - 计算机专业或信息技术相关专业的学生,用于课程学习或考试复习。 - 准备计算机等级考试或职业资格认证的人士,作为实战演练材料。 - 对计算机操作有兴趣的自学者,用于提升个人计算机应用技能。 - 计算机基础教育工作者,作为教学资源或出题参考。 ### 使用场景及目标 1. **学习评估**:作为学校或教育机构对学生计算机基础知识和应用技能的评估工具。 2. **自学测试**:供个人自学者检验自己对计算机知识的掌握程度和操作熟练度。 3. **职业发展**:帮助职场人士通过实际操作练习,提升计算机应用能力,增强工作竞争力。 4. **教学资源**:教师可以用于课堂教学,作为教学内容的补充或学生的课后练习。 5. **竞赛准备**:适合准备计算机相关竞赛的学生,作为强化训练和技能检测的材料。 试卷的目标是通过系统性的题目设计,帮助学生全面复习和巩固计算机基础知识,同时通过实际操作题目,提高学生解决实际问题的能力。通过本试卷的学习与练习,学生将能够更加深入地理解计算机的工作原理,掌握常用软件的使用方法,为未来的学术或职业生涯打下坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值