JPA保存有时生效,有时无效

问题描述:由于项目需要需要定时从其他服务接口查询数据,把符合条件的数据插入预警表,结果发现插入的数据总时插入数据不全或者没插入数据。

原始代码:

public class TestServiceImpl  {

    @Autowired
    private TestServiceImpl testServiceService;
    @Autowired
    private TestDao testDao;

    /**
     *数据保存测试
     *
     * @param testEntity
     */

   @Transactional(rollbackFor = Exception.class)
    public void saveEntity(TestEntity testEntity) {
       String vin = testEntity.getVin();
       Date createDate = testEntity.getCreateDate();
       if (null != createDate) {
           String createDateStr = DateUtil.format(createDate);
           TestEntity originDrivingWarning = testDao.findByVinCAndCreateDate(vin, createDateStr);
           if (null != originDrivingWarning) {
               testEntity.setSid(originDrivingWarning.getSid());
               testEntity.setVersion(originDrivingWarning.getVersion()+ Constants.DEFAULT_ONE);
           }
       }
       testDao.save(testEntity);
    }


    
    /**
     * 校验预警,保存记录
     */

    public void checkWarning() {
        PageDto<TestWarning> pageDto = testDao.findWarningList();
        // 处理数据
        List<TestWarning> rows = pageDto.getRows();
  
        rows.parallelStream().forEach(warningVO->{
            TestEntity  testWarningEntity = new TestEntity();
            testWarningEntity.setVin(warningVO.getVin());
            testWarningEntity.setAddress("上海");
             //保存(问题出现在这)
            testServiceService.saveEntity(testWarningEntity);
        });

    }
}

更改后的代码:

public class TestServiceImpl  {

    @Autowired
    private TestServiceImpl testServiceService;
    @Autowired
    private TestDao testDao;

    /**
     *数据保存测试
     *
     * @param testEntity
     */

   @Transactional(rollbackFor = Exception.class)
    public void saveEntity(TestEntity testEntity) {
       String vin = testEntity.getVin();
       Date createDate = testEntity.getCreateDate();
       if (null != createDate) {
           String createDateStr = DateUtil.format(createDate);
           TestEntity originDrivingWarning = testDao.findByVinCAndCreateDate(vin, createDateStr);
           if (null != originDrivingWarning) {
               testEntity.setSid(originDrivingWarning.getSid());
               testEntity.setVersion(originDrivingWarning.getVersion()+ Constants.DEFAULT_ONE);
           }
       }
       testDao.save(testEntity);
    }


    /**
     * 批量保存数据
     * @param testEntityList
     */
    @Transactional(rollbackFor = Exception.class)
    public void batchSaveEntity(List<TestEntity>
                                            testEntityList) {
        testEntityList.parallelStream().forEach(vo->{
            String vin = vo.getVin();
            Date createDate = vo.getCreateDate();
            if (null != createDate) {
                String createDateStr = DateUtil.format(createDate);
                TestEntity originDrivingWarning = testDao.findByVinCAndCreateDate(vin, createDateStr);
                    if (null != originDrivingWarning) {
                        vo.setSid(originDrivingWarning.getSid());
                        vo.setVersion(originDrivingWarning.getVersion()+ Constants.DEFAULT_ONE);
                     }
                 }
            }
        );

        testDao.save(testEntityList);
    }

    /**
     * 校验预警,保存记录
     */

    public void checkWarning() {
        PageDto<TestWarning> pageDto = testDao.findWarningList();
        // 处理数据
        List<TestWarning> rows = pageDto.getRows();
        List<TestEntity> saveEntityList = new ArrayList<>();
        rows.parallelStream().forEach(warningVO->{
            TestEntity  testWarningEntity = new TestEntity();
            testWarningEntity.setVin(warningVO.getVin());
            testWarningEntity.setAddress("上海");
               //step1:先放在待插入列表
             saveEntityList.add(testWarningEntity);
        });
          
        if(saveEntityList.size()>0){
            //step2:有预警需要保存,则批量保存效率更快。
            testServiceService.batchSaveEntity(saveEntityList);
        }
    }
}

单个插入改成批量插入以同一个事务提交数据。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPA是Java Persistence API的缩写,它是一种用于持久化数据的Java规范。要保存多条数据,可以使用JPA的EntityManager来完成。 首先,我们需要创建一个实体类来映射我们要保存的数据。这个实体类需要使用@Entity注解来标记,并定义对应的属性和表结构。例如,我们可以创建一个实体类User,它包含id、name、age等属性。 接下来,我们可以使用EntityManager的persist方法保存多条数据。首先,我们需要获取一个EntityManager对象,可以通过注入或者创建EntityManagerFactory来获得。然后,我们可以使用EntityManager的beginTransaction方法开启一个事务。 在事务中,我们可以通过实例化多个User对象,并设置它们的属性。然后,我们可以使用EntityManager的persist方法保存这些User对象。在调用persist方法后,实体对象会被标记为持久化状态,但实际的数据库操作会在事务提交时才执行。 最后,我们可以使用事务的commit方法来提交事务。在事务提交后,保存的多条数据会被写入数据库。 以下是一个保存多条User数据的示例代码: ```java EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("yourPersistenceUnitName"); EntityManager entityManager = entityManagerFactory.createEntityManager(); entityManager.getTransaction().begin(); User user1 = new User(); user1.setName("张三"); user1.setAge(20); entityManager.persist(user1); User user2 = new User(); user2.setName("李四"); user2.setAge(25); entityManager.persist(user2); entityManager.getTransaction().commit(); entityManager.close(); entityManagerFactory.close(); ``` 以上是使用JPA保存多条数据的简单步骤。通过使用EntityManager的persist方法和事务的commit方法,我们可以很方便地保存多条数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值