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<Map<String, Object>> pagerList = query.list();

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值