一、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/zh-tw/n/145535.html
微信掃一掃
支付寶掃一掃