Reformat code.

Also, upgrade to Hibernate 7.0 CR1.
This commit is contained in:
Mark Paluch
2025-05-13 16:00:45 +02:00
parent d40fec53e4
commit 2b82d56ded
7 changed files with 170 additions and 177 deletions

View File

@@ -14,7 +14,7 @@
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<hibernate.version>7.0.0.Beta5</hibernate.version>
<hibernate.version>7.0.0.CR1</hibernate.version>
<spring-data-bom.version>2025.1.0-SNAPSHOT</spring-data-bom.version>
</properties>

View File

@@ -24,7 +24,8 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class AotJpaApp {
public static void main(String[] args) {
SpringApplication.run(AotJpaApp.class, args);
}
public static void main(String[] args) {
SpringApplication.run(AotJpaApp.class, args);
}
}

View File

@@ -31,94 +31,95 @@ import org.springframework.stereotype.Component;
@Component
public class CLR implements CommandLineRunner {
@Autowired UserRepository repository;
@Autowired UserRepository repository;
@Override
public void run(String... args) throws Exception {
@Override
public void run(String... args) throws Exception {
User luke = new User("id-1", "luke");
luke.setFirstname("Luke");
luke.setLastname("Skywalker");
// Post lukeP1 = new Post("I have a bad feeling about this.");
// em.persist(lukeP1);
// luke.setPosts(List.of(lukeP1));
User luke = new User("id-1", "luke");
luke.setFirstname("Luke");
luke.setLastname("Skywalker");
// Post lukeP1 = new Post("I have a bad feeling about this.");
// em.persist(lukeP1);
// luke.setPosts(List.of(lukeP1));
User leia = new User("id-2", "leia");
leia.setFirstname("Leia");
leia.setLastname("Organa");
User leia = new User("id-2", "leia");
leia.setFirstname("Leia");
leia.setLastname("Organa");
User han = new User("id-3", "han");
han.setFirstname("Han");
han.setLastname("Solo");
// Post hanP1 = new Post("It's the ship that made the Kessel Run in less than 12 Parsecs.");
// em.persist(hanP1);
// han.setPosts(List.of(hanP1));
User han = new User("id-3", "han");
han.setFirstname("Han");
han.setLastname("Solo");
// Post hanP1 = new Post("It's the ship that made the Kessel Run in less than 12 Parsecs.");
// em.persist(hanP1);
// han.setPosts(List.of(hanP1));
User chewbacca = new User("id-4", "chewbacca");
User yoda = new User("id-5", "yoda");
Post yodaP1 = new Post("Do. Or do not. There is no try.");
Post yodaP2 = new Post("Decide you must, how to serve them best. If you leave now, help them you could; but you would destroy all for which they have fought, and suffered.");
// em.persist(yodaP1);
// em.persist(yodaP2);
// yoda.setPosts(List.of(yodaP1, yodaP2));
User chewbacca = new User("id-4", "chewbacca");
User yoda = new User("id-5", "yoda");
Post yodaP1 = new Post("Do. Or do not. There is no try.");
Post yodaP2 = new Post(
"Decide you must, how to serve them best. If you leave now, help them you could; but you would destroy all for which they have fought, and suffered.");
// em.persist(yodaP1);
// em.persist(yodaP2);
// yoda.setPosts(List.of(yodaP1, yodaP2));
User vader = new User("id-6", "vader");
vader.setFirstname("Anakin");
vader.setLastname("Skywalker");
// Post vaderP1 = new Post("I am your father");
// em.persist(vaderP1);
// vader.setPosts(List.of(vaderP1));
User vader = new User("id-6", "vader");
vader.setFirstname("Anakin");
vader.setLastname("Skywalker");
// Post vaderP1 = new Post("I am your father");
// em.persist(vaderP1);
// vader.setPosts(List.of(vaderP1));
User kylo = new User("id-7", "kylo");
kylo.setFirstname("Ben");
kylo.setLastname("Solo");
User kylo = new User("id-7", "kylo");
kylo.setFirstname("Ben");
kylo.setLastname("Solo");
repository.saveAll(List.of(luke, leia, han, chewbacca, yoda, vader, kylo));
repository.saveAll(List.of(luke, leia, han, chewbacca, yoda, vader, kylo));
System.out.println("------- annotated multi -------");
System.out.println(repository.usersWithUsernamesStartingWith("l"));
System.out.println("------- annotated multi -------");
System.out.println(repository.usersWithUsernamesStartingWith("l"));
System.out.println("------- derived single -------");
System.out.println(repository.findUserByUsername("yoda"));
System.out.println("------- derived single -------");
System.out.println(repository.findUserByUsername("yoda"));
// System.out.println("------- derived nested.path -------");
// System.out.println(repository.findUserByPostsMessageLike("father"));
// System.out.println("------- derived nested.path -------");
// System.out.println(repository.findUserByPostsMessageLike("father"));
System.out.println("------- derived optional -------");
System.out.println(repository.findOptionalUserByUsername("yoda"));
System.out.println("------- derived optional -------");
System.out.println(repository.findOptionalUserByUsername("yoda"));
System.out.println("------- derived count -------");
Long count = repository.countUsersByLastnameLike("Sky");
System.out.println("user count " + count);
System.out.println("------- derived count -------");
Long count = repository.countUsersByLastnameLike("Sky");
System.out.println("user count " + count);
System.out.println("------- derived exists -------");
Boolean exists = repository.existsByUsername("vader");
System.out.println("user exists " + exists);
System.out.println("------- derived exists -------");
Boolean exists = repository.existsByUsername("vader");
System.out.println("user exists " + exists);
System.out.println("------- derived multi -------");
System.out.println(repository.findUserByLastnameStartingWith("Sky"));
System.out.println("------- derived multi -------");
System.out.println(repository.findUserByLastnameStartingWith("Sky"));
System.out.println("------- derived sorted -------");
System.out.println(repository.findUserByLastnameStartingWithOrderByFirstname("Sky"));
System.out.println("------- derived sorted -------");
System.out.println(repository.findUserByLastnameStartingWithOrderByFirstname("Sky"));
System.out.println("------- derived page -------");
Page<User> page0 = repository.findUserByLastnameStartingWith("S", PageRequest.of(0, 2));
System.out.println("page0: " + page0);
System.out.println("page0.content: " + page0.getContent());
System.out.println("------- derived page -------");
Page<User> page0 = repository.findUserByLastnameStartingWith("S", PageRequest.of(0, 2));
System.out.println("page0: " + page0);
System.out.println("page0.content: " + page0.getContent());
Page<User> page1 = repository.findUserByLastnameStartingWith("S", PageRequest.of(1, 2));
System.out.println("page1: " + page1);
System.out.println("page1.content: " + page1.getContent());
Page<User> page1 = repository.findUserByLastnameStartingWith("S", PageRequest.of(1, 2));
System.out.println("page1: " + page1);
System.out.println("page1.content: " + page1.getContent());
System.out.println("------- derived slice -------");
Slice<User> slice0 = repository.findUserByUsernameAfter("luke", PageRequest.of(0, 2));
System.out.println("slice0: " + slice0);
System.out.println("slice0.content: " + slice0.getContent());
System.out.println("------- derived slice -------");
Slice<User> slice0 = repository.findUserByUsernameAfter("luke", PageRequest.of(0, 2));
System.out.println("slice0: " + slice0);
System.out.println("slice0.content: " + slice0.getContent());
System.out.println("------- derived top -------");
System.out.println(repository.findTop2UsersByLastnameStartingWith("S"));
System.out.println("------- derived top -------");
System.out.println(repository.findTop2UsersByLastnameStartingWith("S"));
// System.out.println("------- derived with fields -------");
// System.out.println(repository.findJustUsernameBy());
}
// System.out.println("------- derived with fields -------");
// System.out.println(repository.findJustUsernameBy());
}
}

View File

@@ -30,39 +30,37 @@ import java.util.Random;
@Entity
public class Post {
@Id
@GeneratedValue
private Long id;
@Id
@GeneratedValue private Long id;
private String message;
private Instant date;
private String message;
private Instant date;
public Post() {
}
public Post() {}
public Post(String message) {
this.message = message;
this.date = Instant.now().minus(new Random().nextLong(100), ChronoUnit.MINUTES);
}
public Post(String message) {
this.message = message;
this.date = Instant.now().minus(new Random().nextLong(100), ChronoUnit.MINUTES);
}
public String getMessage() {
return message;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public void setMessage(String message) {
this.message = message;
}
public Instant getDate() {
return date;
}
public Instant getDate() {
return date;
}
public void setDate(Instant date) {
this.date = date;
}
public void setDate(Instant date) {
this.date = date;
}
@Override
public String toString() {
return message;
}
@Override
public String toString() {
return message;
}
}

View File

@@ -28,85 +28,78 @@ import java.time.Instant;
@Entity(name = "users")
public class User {
@Id
private String id;
private String username;
@Id private String id;
private String username;
@Column(name = "first_name") String firstname;
@Column(name = "last_name") String lastname;
@Column(name = "first_name") String firstname;
@Column(name = "last_name") String lastname;
// @OneToMany
// private List<Post> posts;
// @OneToMany
// private List<Post> posts;
Instant registrationDate;
Instant lastSeen;
Instant registrationDate;
Instant lastSeen;
public User() {
}
public User() {}
public User(String id, String username) {
this.id = id;
this.username = username;
}
public User(String id, String username) {
this.id = id;
this.username = username;
}
public String getId() {
return id;
}
public String getId() {
return id;
}
public String getUsername() {
return username;
}
public String getUsername() {
return username;
}
public String getFirstname() {
return firstname;
}
public String getFirstname() {
return firstname;
}
public void setFirstname(String firstname) {
this.firstname = firstname;
}
public void setFirstname(String firstname) {
this.firstname = firstname;
}
public String getLastname() {
return lastname;
}
public String getLastname() {
return lastname;
}
public void setLastname(String lastname) {
this.lastname = lastname;
}
public void setLastname(String lastname) {
this.lastname = lastname;
}
public Instant getRegistrationDate() {
return registrationDate;
}
public Instant getRegistrationDate() {
return registrationDate;
}
public void setRegistrationDate(Instant registrationDate) {
this.registrationDate = registrationDate;
}
public void setRegistrationDate(Instant registrationDate) {
this.registrationDate = registrationDate;
}
public Instant getLastSeen() {
return lastSeen;
}
public Instant getLastSeen() {
return lastSeen;
}
public void setLastSeen(Instant lastSeen) {
this.lastSeen = lastSeen;
}
public void setLastSeen(Instant lastSeen) {
this.lastSeen = lastSeen;
}
// public List<Post> getPosts() {
// return posts;
// }
//
// public void setPosts(List<Post> posts) {
// this.posts = posts;
// }
// public List<Post> getPosts() {
// return posts;
// }
//
// public void setPosts(List<Post> posts) {
// this.posts = posts;
// }
@Override
public String toString() {
return "User{" +
"id='" + id + '\'' +
", username='" + username + '\'' +
", firstname='" + firstname + '\'' +
", lastname='" + lastname + '\'' +
", registrationDate=" + registrationDate +
", lastSeen=" + lastSeen +
// ", posts=" + posts +
'}';
}
@Override
public String toString() {
return "User{" + "id='" + id + '\'' + ", username='" + username + '\'' + ", firstname='" + firstname + '\''
+ ", lastname='" + lastname + '\'' + ", registrationDate=" + registrationDate + ", lastSeen=" + lastSeen +
// ", posts=" + posts +
'}';
}
}

View File

@@ -31,27 +31,27 @@ import org.springframework.data.repository.CrudRepository;
*/
public interface UserRepository extends CrudRepository<User, String>, QuerydslPredicateExecutor<User> {
User findUserByUsername(String username);
User findUserByUsername(String username);
Optional<User> findOptionalUserByUsername(String username);
Optional<User> findOptionalUserByUsername(String username);
Long countUsersByLastnameLike(String lastname);
Long countUsersByLastnameLike(String lastname);
Boolean existsByUsername(String username);
Boolean existsByUsername(String username);
List<User> findUserByLastnameLike(String lastname);
List<User> findUserByLastnameLike(String lastname);
List<User> findUserByLastnameStartingWithOrderByFirstname(String lastname);
List<User> findUserByLastnameStartingWithOrderByFirstname(String lastname);
List<User> findTop2UsersByLastnameStartingWith(String lastname);
List<User> findTop2UsersByLastnameStartingWith(String lastname);
Slice<User> findUserByUsernameAfter(String username, Pageable pageable);
Slice<User> findUserByUsernameAfter(String username, Pageable pageable);
List<User> findUserByLastnameStartingWith(String lastname);
List<User> findUserByLastnameStartingWith(String lastname);
Page<User> findUserByLastnameStartingWith(String lastname, Pageable page);
Page<User> findUserByLastnameStartingWith(String lastname, Pageable page);
@Query("SELECT u FROM example.springdata.aot.User u WHERE u.username LIKE ?1%")
List<User> usersWithUsernamesStartingWith(String username);
@Query("SELECT u FROM example.springdata.aot.User u WHERE u.username LIKE ?1%")
List<User> usersWithUsernamesStartingWith(String username);
}

View File

@@ -1,5 +1,5 @@
spring.jpa.defer-datasource-initialization=true
spring.jpa.properties.hibernate.boot.allow_jdbc_metadata_access=false
spring.aot.repositories.enabled=true
#spring.aot.jpa.repositories.use-entitymanager=true
#logging.level.org.springframework.data.repository.aot.generate.RepositoryContributor=trace