Spring Boot 遇到的坑

    前端时间,公司开始转向Spring Boot 和Spring data jpa。以下是我遇到的几个问题,记录下来方便日后查看:

一:使用springboot 读取数据库时间  相差8个小时:

https://blog.csdn.net/weiguang1017/article/details/78867497

二:关于spring boot jpa的事务问题     

1:JpaRepository中的修改删除操作,需加上注解@Modifying,必须在service中调用,service中加上@Transactional

2:整个项目中要开始事务,即在启动类中添加注解@EnableTransactionManagement

3:service中的事务方法要么不使用try catch,要么在catch中throw异常,否则try catch中发生异常,事务不生效

4:service中的事务方法必须是public的

5:mysql中的MyISAM引擎是不支持事务的,需要改为innodb 引擎

三:关于getSingleResult()方法

使用getSingleResult()方法时,如果没有结果(也就是返回null)时,习惯思维是应该返回null,而getSingleResult()方法中有这么一条语句: @throws EntityNotFoundException if there is no result 

也就是说,当他查询不到结果时,将会抛出EntityNotFoundException异常,而不是返回null。 

四:使用EntityManager的unwrap方法,转换为Hibernate的Session执行sql,可以获取Map类型的数据集合

Session session = entityManager.unwrap(Session.class);
org.hibernate.Query query = session.createSQLQuery(querySql);
query.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
List> pagerList = query.list();

 

你可能感兴趣的:(spring,boot)