目录:
- 1、@Transactional注解控制事务有哪些不生效的场景
- 2、MySQL的优化
1、@Transactional注解控制事务有哪些不生效的场景
- 数据库引擎不支持事务
- 数据源没有配置事务管理器
- 没有被spring管理
- 方法不是public的
- 同一个类中方法调用,导致@Transactional失效
举例最后一个的解决办法:
- 第一种解决办法,新建一个类一个方法,在a中注入新类,再通过新类调用事务注解的方法。
- 第二种解决方法,就是在该类中注入自己,通过在a方法中,通过自己类的对象调用b的事务注解方法。
2、MySQL的优化
- 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划
- SQL语句中IN包含的值不应过多
- SELECT语句务必指明字段名称
- 当只需要一条数据的时候,使用limit 1
- 如果限制条件中其他字段没有索引,尽量少用or
- 尽量用union all代替union(使用union all前提是两张表没有重复数据)
- 使用合理的分页方式以提高分页的效率(数据量太大,分页会越来越慢,建议使用id为条件来进行分页处理更快)
- 分段查询(数据达到百万级,可以使用分段查询,循环展示数据,要的时候再加载数据)
- 避免在where子句中对字段进行null值判断
- 不建议使用%前缀模糊查询
- 避免在where子句中对字段进行表达式操作
- 对于联合索引来说,要遵守最左前缀法则(举列来说索引含有字段id、name、school,可以直接用id字段,也可以id、name这样的顺序,但是name;school都无法使用这个索引。所以在创建联合索引的时候一定要注意索引字段顺序,常用的查询字段放在最前面。)
- 注意范围查询语句(对于联合索引来说,如果存在范围查询,比如between、>、<等条件时,会造成后面的索引字段失效。)
- JOIN优化尽量使用inner join(等值关联查询),尽量使用小表来驱动大表。
19种优化建议