Spring Boot 遇到的坑

公司转向使用Spring Boot和Spring Data JPA,作者记录遇到的几个问题。包括读取数据库时间相差8小时,JPA事务问题(如注解使用、引擎选择等),getSingleResult()方法无结果会抛异常,以及使用EntityManager的unwrap方法获取Map类型数据集合。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    前端时间,公司开始转向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();

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值