前端时间,公司开始转向Spring Boot 和Spring data jpa。以下是我遇到的几个问题,记录下来方便日后查看:
一:使用springboot 读取数据库时间 相差8个小时:
https://blog.youkuaiyun.com/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<Map<String, Object>> pagerList = query.list();