面试总结(1)

spring事务的传播

事务的四个属性:
原子性
事务是一个原子操作,由一系列动作组成,确保原子内的动作要么全部完成,要么全部失效。
一致性
当事务完成时,事务会被提交,数据会保持一致性,要么统一完成,要么统一失效。
隔离性
事务与事务之间相互隔离,防治数据损坏
持久性
一旦事务完成后,无论系统发生什么错误,结果都不应受到影响,数据应被持久化到数据库中。

事务的传播属性
事务的传播主要指的是:A有一个事务,B有一个事务,当在A中调用B方法时,事务的一个解决方案。
required
如果有事务在运行,当前的方法就在这个事务内运行,否则就启动一个事务,并在自己的事务中运行。简言之就是必须需要事务进行支撑。
required_New
当前方法必须需启动新的事务,并且在新的事务中运行,如果本来有事务在运行,则将该事务挂起。
supports
如果有事务就在事务中运行,否则可以不在事务中运行
not_support
当前方法不应该在事务中运行,如果有事务,应该将它挂起。
mandatory
当前的方法必须在事务中运行,如果没有事务就抛出异常。
never
当前方法不能在事务中运行,如果有事务就抛出异常
nested
如果当前有事务在运行,那么就在当前事务的嵌套事务中运行,否则就开启新的事务,并在新的事务中运行。

事务的隔离级别
default
使用数据库默认的隔离级别,一般默认的都是read_commit
read_uncommit
允许读取未被别的事务提交的变更,锁的程度最低,脏读、幻读、不可重复读的情况都会出现
read_commit
只可以允许读取事务被提交的了数据。
repeatable_read
确保事务可以多次读取同一数据,事务在读取期间拒绝其他事务访问
但幻读问题仍然存在
serializable
锁的最高级别,可以杜绝脏读、幻读和不可重复读,但是效率低下。

mybaitis中类名和配置文件中的名字必须一致吗?区分大小写吗?

用过哪些同步锁?

知道继承于lock和继承于synchronize的锁的区别吗?
lock是一个接口,子类提供lock和unlock方法,支持手动上锁和解锁。灵活性比较高。readwrite还提供读的时候共享,写的时候独占。
synchronize是java提供的一个锁的实现,自动管理加锁和释放的过程。

对于事务一般是怎么处理的?

servlet生命周期解释一下?
当前端请求第一次过来的时候,会通过init()初始化servlet,并放入容器中,然后调用service()方法提供具体的服务,然后在servlet服务器关闭时调用destroy()方法进行销毁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值