一、JPA批量更新
1、JPA批量更新是指在一次事务中批量更新多条记录,而不是单独一条一条更新。这样可以减少事务的次数,提高了性能。
2、示例代码:
@Transactional
public void batchUpdate(List students) {
// 获取JPA实体管理器
EntityManager entityManager = entityManagerFactory.createEntityManager();
// 开启事务
EntityTransaction transaction = entityManager.getTransaction();
transaction.begin();
// 批量更新
for (Student student : students) {
entityManager.merge(student);
}
// 提交事务
transaction.commit();
// 关闭实体管理器
entityManager.close();
}
3、批量更新时,需要注意的是所有对象的状态都应该为托管状态,否则可能会引起异常。
二、JPA操作数据库
1、JPA中可以使用EntityManager来操作数据库,它提供了一些常用的方法,如:persist、merge、find、remove、createQuery 等。其中,merge 方法用于更新一条记录。
2、示例代码:
@Transactional
public void updateStudent(Student student) {
// 获取JPA实体管理器
EntityManager entityManager = entityManagerFactory.createEntityManager();
// 开启事务
EntityTransaction transaction = entityManager.getTransaction();
transaction.begin();
// 更新
entityManager.merge(student);
// 提交事务
transaction.commit();
// 关闭实体管理器
entityManager.close();
}
3、EntityManager 还可以使用 Criteria API 进行动态查询和更新操作。Criteria API 可以在运行时动态生成 JPQL 语句,可以更加灵活地操作数据库。
三、JPA更新操作
1、JPA 提供了对实体的 CRUD 操作,包括增加、查询、修改和删除,在修改实体时可使用以下几种方式:
2、示例代码:
// 第一种方式,通过 EntityManager 的 merge 方法来更新实体
student.setName("Tom");
entityManager.merge(student);
// 第二种方式,通过主键查找到对象,然后修改它的属性
Student student = entityManager.find(Student.class, 1L);
student.setName("Tom");
entityManager.merge(student);
// 第三种方式,通过 JPQL 语句来更新实体
Query query = entityManager.createQuery("update Student s set s.name = :name where s.id = :id");
query.setParameter("name", "Tom");
query.setParameter("id", 1L);
query.executeUpdate();
// 第四种方式,使用 Criteria API 来更新实体
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaUpdate criteriaUpdate = criteriaBuilder.createCriteriaUpdate(Student.class);
Root root = criteriaUpdate.from(Student.class);
criteriaUpdate.set("name", "Tom");
criteriaUpdate.where(criteriaBuilder.equal(root.get("id"), 1L));
entityManager.createQuery(criteriaUpdate).executeUpdate();
// 第五种方式,使用 Spring Data JPA 的 save 方法来更新实体
student.setName("Tom");
studentRepository.save(student);
3、需要注意的是,如果多次调用 merge 方法更新同一个实体时,每次都会在数据库中创建一条新记录,这是因为每次 merge 方法会返回一个新对象,而不是原有的对象。
原创文章,作者:LUPA,如若转载,请注明出处:https://www.506064.com/n/145535.html
微信扫一扫
支付宝扫一扫