当前位置: 首页 > news >正文

微商城网站建设案例深圳搜索引擎优化收费

微商城网站建设案例,深圳搜索引擎优化收费,网页游戏平台有哪些,java做网站连sqlsever事务的四大特性 1.原子性(Atomicity):事务不可再分,要么都执行,要么都不执行。 2.一致性(Consistency):事务执行前后,数据的完整性保持一致,即修改前后数据总…

 事务的四大特性

1.原子性(Atomicity):事务不可再分,要么都执行,要么都不执行。
2.一致性(Consistency):事务执行前后,数据的完整性保持一致,即修改前后数据总量是一样的大概。
3.隔离性(Isolation):一个事务执行过程中,不会受到其他事务干扰。
4.持久性(Durability):事务一旦结束,对数据库的影响是永久的。数据持久化到数据库中。在并行程序中可能会出现的问题

脏读:当 A事务 读取 B事务 未提交的数据后,B事务 回滚,导致 A事务 读取到的数据为脏数据。
不可重复读:A事务 读取第一次读取数据后,B事务 对该数据进行了修改并提交,A事务 再去读取数据时,前后数据结果不一致。
幻读:A事务 读取第一次读取数据后,B事务 又插入或删除了新的数据并提交,A事务 再去读取数据时,前后结果不一致。
事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。事务通常由高级数据库操纵语言或编程语言(如 SQL、C++ 或 Java)书写的用户程序的执行所引起,并用形如 begin transaction 和 end transaction 语句(或函数调用)来界定。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。例如:在关系数据库中,一个事务可以是一条 SQL 语句,一组 SQL 语句或整个程序。

事务隔离级别定义了在一个事务中,哪些数据是对当前执行的语句“可见”的。在并发访问数据库时,事务隔离级别定义了多个事务之间对于同个目标数据源访问时的可交叉程度。
可交叉程度

1.Dirty Read(脏读) 看到的数据则是不正确的

当一个事务能看见另外一个事务未提交的数据时,就称为脏读。如果这个事务被回滚而不是提交了,那么其它事务看到的数据则是不正确的,是“脏”的。

 

2.Non-repeatable Read(不可重复读) 两次读取到的数据不同

假设事务 A 读取了一行数据,接下来事务 B 改变了这行数据,之后事务 A 再一次读取该行数据,结果就是事务 A 两次读取到的数据不同。

3.Phantom Read(幻读) 发现多出来一条数据

假设事务 A 通过一个 where 条件读取到了一个结果集,此时事务 B 插入了一条符合事务 A 的 where 条件的数据,之后事务 A 再次执行同样的查询时,发现多出来一条数据。

 

三、事务隔离级别(Isolation)
JDBC 规范增加了隔离级别,来满足了 SQL:2003 定义的 4 种事务隔离级别。在安装MySQL时,安装默认的隔离级别就是:可重复读。来查看当前隔离级别。隔离级别从最宽松到最严格,排序如下所示:

1.TRANSACTION_NONE
这意味着当前的 JDBC 驱动不支持事务,也意味着这个驱动不符合 JDBC 规范。

2.READ_UNCOMMITTED(读未提交)
允许事务看到其它事务修改了但未提交的数据,这意味着有可能是脏读、不可重复读或者幻读。

3.READ_COMMITTED(读提交)
一个事务在未提交之前,所做的修改不会被其它事务所看见。这能避免脏读,但避免不了不可重复读和幻读。

4.REPEATABLE_READ(可重复读取) MySQL默认的事务隔离级别
避免了脏读和不可重复读,但幻读依然是有可能发生的。

5.SERIALIZABLE(序列化)
避免了脏读、不可重复读以及幻读。

四、Propagation:用来枚举事务的传播行为
所谓事务的传播行为就是多个事务方法相互调用时,事务如何在这些方法间传播。Spring 支持 7 种事务传播行为,默认为 REQUIRED。

1.REQUIRED
@Transactional(propagation=Propagation.REQUIRED)
如果当前有事务,加入到这个事务中。如果当前没有事务,就新建一个事务。

2.REQUIRES_NEW
@Transactional(propagation=Propagation.REQUIRES_NEW)
不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务。表示当前方法必须运行在它自己的事务中。如果使用 JTATransactionManager 的话,则需要访问 TransactionManager。

3.MANDATORY
@Transactional(propagation=Propagation.MANDATORY)
表示该方法必须在事务中运行,如果当前不存在事务,则会抛出一个异常。不会主动开启一个事务。

4.NEVER
@Transactional(propagation=Propagation.NEVER)
表示该方法不应该运行在事务上下文中,如果当前正有一个事务在运行,则会抛出异常。(与Propagation.MANDATORY相反)。

5.SUPPORTS
@Transactional(propagation=Propagation.SUPPORTS)
表示当前方法不需要事务上下文,但是如果存在当前事务的话,那么这个方法会在这个事务中运行。

6.NOT_SUPPORTED
@Transactional(propagation=Propagation.NOT_SUPPORTED)
表示该方法不应该运行在事务中,如果存在当前事务,在该方法运行期间,当前事务将被挂起。如果使用 JTATransactionManager 的话,则需要访问 TransactionManager。

7.NESTED
@Transactional(propagation=Propagation.NESTED)
表示如果当前已经存在事务,那么该方法将会在嵌套事务中运行。嵌套的事务可以独立于当前事务进行单独地提交或回滚。如果当前不存在事务,那么其行为等价于 Propagation.REQUIRED。嵌套事务一个非常重要的概念就是内层事务依赖于外层事务。外层事务失败时,会回滚内层事务所做的动作。而内层事务操作失败并不会引起外层事务的回滚。

综上所述,NESTED 和 REQUIRES_NEW 非常相似,都是开启一个属于它自己的新事务。使用 REQUIRES_NEW 时,内层事务与外层事务就像两个独立的事务一样,一旦内层事务进行了提交后,外层事务不能对其进行回滚。当内部事务开始执行时, 外部事务将被挂起,内务事务结束时,外部事务将继续执行。两个事务互不影响,两个事务不是一个真正的嵌套事务,同时它还需要 JTA 事务管理器的支持。

使用 NESTED 时,外层事务的回滚可以引起内层事务的回滚,而内层事务的异常并不会导致外层事务的回滚,它是一个真正的嵌套事务。嵌套事务开始执行时,它将取得一个 savepoint,如果这个嵌套事务失败,将回滚到此 savepoint。嵌套事务是外部事务的一部分,只有外部事务结束后它才会被提交。
 

 

 

http://www.mmbaike.com/news/57308.html

相关文章:

  • 罗永浩做的网站网站管理与维护
  • 岳阳网站建设文案发布平台
  • 仿券妈妈网站开发营销背景包括哪些内容
  • 网络营销顾问是做什么的杭州seo按天计费
  • html5商城网页模板超级推荐的关键词怎么优化
  • 类似b站的网站怎么做的网络舆情监测
  • 网站开发和网络工程哪个好网站推广苏州
  • 无锡做网站好西安网站定制开发
  • 松岗做网站公司百度官网首页
  • 网站定制化开发网站改版seo建议
  • 杭州 网站建设 哪家强安卓优化大师app下载安装
  • 内存做硬盘缓存软件网站西安seo推广
  • dw怎么做秋季运动会网站seo优化教程自学
  • 微网站自助建设移动端关键词排名优化
  • 网站的登陆注册页面怎么做百度代理推广
  • 微信里的小程序怎么制作方法云优化软件
  • wordpress做视频网站吗衡阳有实力seo优化
  • 代刷网站怎么做关键词排名监控
  • 网站建设与运营公司部门结构优化网站做什么的
  • wordpress图文简介文章页seo在线优化排名
  • 网站制作自己做服务器网络推广公司网站
  • 互联网保险发展现状站外seo是什么
  • 没网站怎么做淘宝客今晚赛事比分预测
  • win7用自己ip做网站西安网络公司
  • 苏州seo推广优化武汉seo论坛
  • 做lol数据的网站有哪些怎么做app推广和宣传
  • 做qq阅读网站介绍网络推广公司企业
  • 网站建设课程的认识制作网站需要多少费用
  • 医院网站建设的规划方案百度服务电话在线人工
  • 帝国做网站是选择静态还是伪静态百度互联网营销