일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 자바
- QueryDSL
- Proxy
- Spring Boot
- http
- pointcut
- 알고리즘
- JPQL
- springdatajpa
- spring
- 스프링
- jpa
- Greedy
- AOP
- 백준
- 인프런
- 김영한
- 스프링 핵심 기능
- 스프링 핵심 원리
- Thymeleaf
- Exception
- JDBC
- transaction
- java
- db
- 그리디
- Android
- kotlin
- SpringBoot
- Servlet
- Today
- Total
목록jpa (149)
개발자되기 프로젝트
예를들어 모든 인원의 나이를 하나 씩 올리거나, 연봉을 올리거나 할 때, 엔티티를 하나하나 불러와서 업데이트 하는 것 보다. DB에서 bulk로 변경하는 편이 적합하다. 1. JPA로 bulk 연산 executeUpdate()를 실행하면 업데이트, 삭데된 엔티티의 수를 반환. public int bulkAgePlus(int age){ return em.createQuery("update Member m set m.age = m.age + 1 where m.age >= :age") .setParameter("age", age) .executeUpdate(); //Returns: the number of entities updated or deleted } public int bulkAgePlus(int a..
1. JPA 의 페이징 JPA에서 페이징 하는 방법 조건 검색 조건 : 나이 10살 정렬 조건 : 이름으로 내림차순 페이징 조건 : 첫 번째 페이지, 페이지 당 보여 줄 데이터는 3건 2. 예제 setFirstResult() : 몇 번 째 부터? setMaxResult() : 몇 개? public List findbyPage(int age, int offset, int limit){ return em.createQuery("select m from Member m where m.age = :age order by m.userName desc") .setParameter("age", age) .setFirstResult(offset) //몇 번째부터? .setMaxResults(limit) // 몇 개? ..
1. JPA 반환 타입 @Test public void returnType(){ Member member1 = new Member("aaa", 10); Member member2 = new Member("bbb", 20); memberRepository.save(member1); memberRepository.save(member2); List members = memberRepository.findListByUserName("aaa"); Optional optionalMember = memberRepository.findOptionalByUserName("aaa"); Member findMember = memberRepository.findMemberByUserName("aaa"); /** * Coll..
1. 이름기반, 위치기반 파라미터 바인딩 이름기반 안씀 ㅋㅋㅋㅋㅋㅋ 가독성과,, 유지보수를 위해 이름기반을 쓰자. 위치기반은 순서가 바뀌면....어우.. select m from Member m where m.username = ?0 //위치 기반 select m from Member m where m.username = :name //이름 기반 @Pram으로 이름기반 바인딩. @Query("select m from Member m where m.username = :name") Member findMembers(@Param("name") String username); 2. 컬렉션 파라미터 바인딩 Collection 타입으로 in절 지원 Query의 "names"에 List names가 바인딩됨. 즉 ..
1. 등록된 회원들의 이름을 조회 MemberRepository @Query("select m.userName from Member m") List findUserNameList(); Test @Test public void findUserNameList(){ Member member1 = new Member("aaa", 10); Member member2 = new Member("bbb", 20); memberRepository.save(member1); memberRepository.save(member2); List userNameList = memberRepository.findUserNameList(); for (String userName : userNameList) { System.out.p..
1. @Query SpringDataJPA를 활용하여 repository의 method에 바로 쿼리를 정의하자. 실무에서 많이 쓰임 기존 SpringDataJPA에서 제공하는 기능은 조건이 너무 길어지면 method이름이 길어졌다. @Query를 사용하면 method이름은 간략히, 쿼리는 여러 조건을 추가할 수 있다. public interface MemberRepository extends JpaRepository { public List findMemberByUserNameAndAgeGreaterThan(String userName, int age); @Query(name = "Member.findByUserName") List findByUserName(@Param("userName") String..
1. Query Method의 기능 메소드 이름으로 쿼리 생성 NamedQuery @Query - 리파지토리 메소드에 쿼리 정의 파라미터 바인딩 반환 타입 페이징과 정렬 벌크성 수정 쿼리 @EntityGraph 2. 메소드 이름으로 쿼리 생성 메소드 이름을 분석해서 JPQL 쿼리 실행 이름과 나이를 기준으로 회원을 조회하려면? 먼저 JPA로 짜보자 public List findMemberByUserNameAndAgeGreaterThan(String userName, int age){ return em.createQuery("select m from Member m where m.userName = :userName and m.age > :age") .setParameter("userName", userN..
1. 공통 인터페이스 설정 JavaConfig 설정- 스프링 부트 사용시 생략 가능(JpaRepository가 있는 pacakge 지정) @Configuration @EnableJpaRepositories(basePackages = "jpabook.jpashop.repository") public class AppConfig {} 스프링 부트 사용시 @SpringBootApplication 위치를 지정(해당 패키지와 하위 패키지 인식) 만약 위치가 달라지면 @EnableJpaRepositories 필요 2. Spring Data JPA 동작 방식 Spring이 JpaRepository를 상속받은 interface의 구현체를 만들어서 주입. org.springframework.data.repository...