springboot 6

[Spring Boot] @Query 어노테이션을 이용한 Spring JPA 예제

안녕하세요. hia의 개발 story입니다. 장점이 많은 Spring JPA이지만 복잡한 쿼리를 사용할 때에는 사용이 불편해집니다. 이런 불편함을 감소시키기 위해 @Query 어노테이션을 이용하여 JPQL문을 실행합니다. JPQL은 일반 SQL처럼 사용가능하기 때문에 좀 더 복잡한 구문을 사용할 수 있습니다. @Query를 이용한 select 구문 테스트 간단하게 select하는 예제를 보도록 하겠습니다. 아래와 같이 Repository 인터페이스에 @Query("쿼리문") 어노테이션을 이용하여 select 하는 함수를 만들어줍니다. public interface SampleRepository extends JpaRepository { @Query("select s from Sample s order b..

Springboot 2023.06.13

[Spring Boot] JpaRepository에서의 쿼리메서드

안녕하세요. hia의 개발 story입니다. Spring JPA의 경우 여러 가지의 검색 조건에 필요한 기능들을 제공합니다. 쿼리 메서드 : 메서드가 쿼리의 구문으로 처리되도록 하는 기능 @Query : SQL처럼 만들기 위해 엔티티 클래스의 정보를 이용해 쿼리를 작성하는 기능 Querysl 등의 동적 쿼리 처리 기능 오늘은 이 중에서 쿼리 메서드에 대해서 공부하려고 합니다. 쿼리 메서드 쿼리 메서드 문서는 아래 페이지에서 찾아볼 수 있습니다. 처음부터 문서만 봐서는 활용하기 어려우니 기초적인 부분을 정리해보려고 합니다. Spring Data JPA - Reference Documentation Example 119. Using @Transactional at query methods @Transacti..

Springboot 2023.03.31

[Spring Boot] JpaRepository의 페이징 및 정렬 처리 하기

안녕하세요. hia의 개발 story입니다. 오늘은 JpaRepository를 이용해 페이징 처리와 정렬 처리를 해보려고 합니다. 지난번에 만든 테이블에는 데이터가 부족하니 sample 테이블에 페이징을 볼 수 있는 데이터를 50개 정도 넣도록 하겠습니다. 이제 CRUD 테스트를 위해 만들었던 SampleRepositoryTests를 이용해 계속 테스트를 해보겠습니다. 페이징 처리 : findAll() 페이징 처리는 findAll() 메서드를 이용하면 됩니다. 이때 findAll( )의 매개변수로 Pageable을 사용하면 Page 로 반환을 하게 되어있습니다. 아래의 소스로 페이징 되어 나오는 데이터를 확인할 수 있습니다. @Test public void pageTest(){ Pageable pagea..

Springboot 2023.03.22

[Spring Boot] JpaRepository를 이용한 CRUD 테스트 예제 공부

안녕하세요. hia의 개발 story입니다. 오늘은 저번에 만들었던 Sample 테이블을 이용하여 JpaRepository 테스트를 해보려고 합니다. JpaRepository를 이용하면 SQL 없이 CRUD 작업을 할 수 있습니다. 개발자에게는 엄청나게 시간을 아껴주는 고마운 친구인 것이죠. JpaRepository CRUD 메서드 insert : save(엔티티 객체) select : findById(키 타입), getOne(키 타입) update : save(엔티티 객체) delete : deleteById(키 타입), delete(엔티티 객체) 특이한 점은 insert와 update 모두 save()라는 메서드를 사용하는데 이는 JPA가 메모리상에서 객체를 비교하고 없으면 insert, 존재하면 u..

Springboot 2023.03.21

[Spring Boot] MariaDB와 Spring JPA 사용하기

안녕하세요. hia의 개발 story입니다. 오늘은 스프링 JPA에 관한 글을 쓰려고 합니다. Spring JPA는 공식 홈페이지에서 설명하는 것과 같이 Spring에서 Jakarta Persistence API(JPA)를 사용할 수 있도록 하는 것입니다. JPA 데이터소스에 접근하기 쉽도록 만들어져 있어 간단한 설정만으로도 JPA를 사용할 수 있습니다. CRUD(Crate, Read, Update, Delete) 작업을 쉽게 처리할 수 있습니다. Spring Data JPA - Reference Documentation Example 119. Using @Transactional at query methods @Transactional(readOnly = true) interface UserReposi..

Springboot 2023.03.14

[Spring Boot] Thymeleaf를 이용한 header, footer 등 공통 페이지 조각 만들기

안녕하세요. hia의 개발 story입니다. 홈페이지를 만들기에 앞서 페이지를 조각내 보려고 합니다. 프런트를 만들 때 보통 공통으로 들어가는 페이지가 있습니다. 특히나 header, footer 파일이 가장 대표적입니다. 쉽게 말해서 홈페이지의 어느 페이지를 들어가더라도 떠있어야 하는 파일을 따로 만들어두는 것입니다. 그러면 페이지마다 같은 부분을 고칠 필요 없이 조각난 파일만 수정을 하면 되기 때문에 선택이 아닌 필수 사항입니다. Thymeleaf에 들어가면 이렇게 공식 문서를 볼 수가 있습니다. 이제 이 문서를 사용해서 fragment 조각들을 만들어봅시다. Thymeleaf Page Layouts - Thymeleaf Summary In this article, we described many w..

Springboot 2022.12.14