@Transactional(readOnly = true)
有很多优点。
- 性能改进:只读实体不进行脏检查
- 节省内存:不维护持久状态的快照
- 数据一致性:只读实体的更改不会持久化
- 当我们使用主从或读写副本集(或集群)时,
@Transactional(readOnly = true)
使我们能够连接到只读数据库
但是,您还应该记住,@Transactional(readOnly = true)
在服务层的方法中可能会导致数据库死锁、性能低下和数据库连接匮乏!
当您需要将只读查询仅仅作为一个事务执行时,请毫不犹豫选择的在服务层的方法中使用@Transactional(readOnly = true)
,如果你的服务层的方法中有大量其他逻辑方法时,就要做取舍了!