会话与事务



如果一个会话断开和数据库的连接,而没有使用commit或rollback终止当前事务,那么该事务会自动被数据库撤销(roll back)
在您退出Sql*Plus时,会自动发出一条commit命令



事务由一系列SQL语句组成,一个事务就是一个整体成败的单元



事务的结束方式有两种:提交和回滚



事务控制语句
Commit 完成事务,数据修改成功并对其他用户开放
Rollback 撤消事务,撤消所有操作
SAVEPOINT 设置回滚点
Rollback to savepoint  撤消在设置的回滚点以后的操作



在启动一个块时,不代表该事务被启动了。事务的开始不需要和块的开始相一致



锁的概念
锁用来锁定相关资源,锁归事务所有
锁是数据库用来控制共享资源并发访问的机制
锁用于保护正在被修改的数据
在事务开始或开始后的某一时刻,事务依情况取得相应的锁,直到事务结束事务所持有的所有的锁才被释放



锁定的优点
并行性 -允许多个用户访问同一数据
一致性 - 一次只允许一个用户修改数据
完整性 - 为所有用户提供正确的数据。如果一个用户进行了修改并保存,所做的修改将反映给所有用户
锁的分类:
 行级锁:对正在被修改的行进行锁定。其他用户可以访问除被锁定的行以外的行
 顾名思义行锁不会锁住整张表,它仅锁住相关行。行锁都是排它的。
 一般的查询语句如select ... from ...语句影响的行不会被锁住
 但select ... from ... for update语句影响的行会被行级排它锁住。其他事务只能查询这些数据行,不能进行update、delete或select...for update操作
 insert / update / delete ...语句影响的行会被行级排它锁住。其他事务只能查询这些数据行,不能进行update、delete或select...for update操作。
 表级锁
  锁定整个表,限制其他用户对表的访问
      --->表级共享锁LOCK TABLE  <table_name> IN SHARE MODE
   该语句将在<table_name>上设置表级共享锁。该锁设置之后,其他事务仅能查看<table_name>表,不能增、删、改



<table_name>表,其他事务可同时放置表级共享锁于<table_name>表上。
       --->表级排它锁LOCK TABLE <table_name> IN EXCLUSIVE MODE
   表级排它锁与表级共享锁非常相似,但每次只有一个用户可以在表中放置排它锁,却可以有多个用户同时在同一个



表中放置共享锁。




事务阻塞 :



当A事务锁住了某种资源,而同时B事务发出对这种资源的修改语句,则B事务将会被阻塞
我们可规定等待他事务释放锁的等待时间,如:
select ... from ... for update wait 10;           ------将会等待10秒
LOCK TABLE table1 IN EXCLUSIVE MODE NOWAIT;




死锁:
当两个事务相互等待对方释放资源时,就会形成死锁
Oracle会自动检测死锁,并通过结束其中的一个事务来解决死锁
右边是一个死锁的例子


转载于:https://blog.51cto.com/youxue/49557