List<Post> posts = entityManager.createQuery("from Post", Post.class).getResultList(); for(Post p : posts) { p.setStatus(Status.OLD); } // Hibernate will send UPDATE 1, UPDATE 2, UPDATE 3...
While free PDFs float around the internet, the official, up-to-date version is worth the investment. It includes the "Ultimate Hibernate Performance Tuning Checklist" —a two-page PDF inside the main PDF that can fix 90% of production latency issues in 15 minutes. High-performance Java Persistence.pdf
In the modern software development landscape, database access is rarely the bottleneck—except when it is. For many Java applications, particularly those built on the monolithic Spring Boot or Jakarta EE architectures, the @Transactional annotation is both a blessing and a curse. While it simplifies code, it often masks inefficient SQL statements, N+1 query issues, and suboptimal locking strategies. List<Post> posts = entityManager
Vlad Mihalcea’s work stands out because it is not academic. It is pragmatic. For every pattern (e.g., "Use a DTO projection"), there is a counter-pattern (e.g., "Avoid DTO projections for graph of objects") with specific benchmarks to prove the point. Vlad Mihalcea’s work stands out because it is not academic
Vlad Mihalcea argues that you cannot write high-performance data access code unless you understand the underlying database. The PDF is structured into three distinct parts, which we will unpack below. Most developers skip the connection pool chapter. They shouldn't.
High-performance Java persistence isn't about writing less SQL; it's about writing smarter JPA.