Oracle操作(一)

一、事务
在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个工作单元操作,要么一个也不执行。
1、事务具有的特性:

  • 原子性(Atomicity):一个事务里面所有包含的SQL语句是一个执行整体,不可分割,要么都做,要么都不做。
  • 一致性(Consistency):事务开始时,数据库中的数据是一致的,事务结束时,数据库的数据也应该是一致的。
  • 隔离性(Isolation):是指数据库允许多个并发事务同时对其中的数据进行读写和修改的能力,隔离性可以防止事务的并发执行时,由于他们的操作命令交叉执行而导致的数据不一致状态。
  • 持久性 (Durability) : 是指当事务结束后,它对数据库中的影响是永久的,即便系统遇到故障的情况下,数据也不会丢失。

2、事务控制命令
(1)提交事务
在执行使用commit语句可以提交事务,当执行了commit语句后,会确认事务的变化,结束事务,删除保存点,释放锁。当使用commit语句结束事务之后,其他会话将可以查看到事务变化后的新数据。
对于每个session而言,每个数据库的更新操作在事务没有被提交之前都只是暂时保存在一段缓冲区中,并不会真正向数据库发出命令,因此在commit之前在其他session中查询不到该操作。
(2)回滚事务
可以设置保存点savepoint sp_a,执行rollback至保存点rollback to sp_a

二、锁
某个session对数据库进行操作时会对操作的数据或数据表锁定,其他的session必须等待提交或回滚后才能进行操作。
(1)行级锁定
当用户执行insert、update、delete、select for update时,oracle会隐式的执行记录的锁定,如果没有提交,会以独占的方式锁定这些操作,其他事务等到锁释放后才能进行操作。
假设在一个session中update表emp:

update emp set sal=6000 where empno=7368;

在另一个session中重复执行该操作,该操作不会被执行,直到第一个session被提交或回滚。
(2)表级锁定

lock table 表名|视图名,表名|视图名... in 锁定模式 mode nowait

锁定有以下几种模式
这里写图片描述
1
解除锁定:

alter system kill session 'sid,serial#';

查询sid、serial#:
通过v$session数据字典

select sid,serial#,status from v$session;

如果用户没有权限的话,以system登陆,grant select any dictionary to 用户名;,即给”用户名”授予所有权限,授权后再执行查询数据字典。查看status为inactive的记录,即为所需的sid、serial#。

(3)悲观锁和乐观锁
表锁行锁针对的是数据库 ,乐观锁悲观锁是一种概念。

  • 悲观锁总是假设最坏的情况,每次取数据时都认为其他线程会修改,所以都会加锁(读锁、写锁、行锁等),当其他线程想要访问数据时,都需要阻塞挂起。可以依靠数据库实现,如行锁、读锁和写锁等,都是在操作之前加锁,在Java中,synchronized的思想也是悲观锁。
  • 乐观锁总是认为不会产生并发问题,每次去取数据的时候总认为不会有其他线程对数据进行修改,因此不会上锁,但是在更新时会判断其他线程在这之前有没有对数据进行修改,一般会使用版本号机制或CAS操作实现。
    version方式:一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数据被修改时,version值会加一。当线程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取到的version值为当前数据库中的version值相等时才更新,否则重试更新操作,直到更新成功。
    核心SQL代码: update table set x=x+1, version=version+1 where id=#{id}
    and version=#{version};
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值