일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- spring
- 그리디
- 스프링 핵심 원리
- db
- Servlet
- java
- 김영한
- JDBC
- transaction
- SpringBoot
- JPQL
- AOP
- 자바
- 스프링 핵심 기능
- Proxy
- Thymeleaf
- Greedy
- Exception
- 스프링
- QueryDSL
- 알고리즘
- Spring Boot
- springdatajpa
- jpa
- 인프런
- 백준
- http
- pointcut
- Android
- kotlin
- Today
- Total
목록springdatajpa (16)
개발자되기 프로젝트
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. @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...
1. 순수 JPA기반 Repository @Repository public class TeamRepository { @PersistenceContext private EntityManager em; public Team save(Team team){ em.persist(team); return team; } public void delete(Team team){ em.remove(team); } public List findAll(){ return em.createQuery("select t from Team t", Team.class).getResultList(); } public Optional findById(Long id){ Team findTeam = em.find(Team.class, id);..
1. Entity Class Member와 Team은 다대일 연관관계 2. ERD 3. Member class xToOne은 기본적으로 fetch type이 EAGER이다. 항상 LAZY를 적용하자(지연로딩) package study.datajpa.entity; import lombok.*; import javax.persistence.*; @Entity @Getter @Setter @NoArgsConstructor(access = AccessLevel.PROTECTED) @ToString(of = {"id", "userName", "age"}) public class Member { @Id @GeneratedValue @Column(name = "member_id") private Long id; pr..
1. application.yml spring: datasource: url: jdbc:h2:tcp://localhost/~/datajpa username: sa driver-class-name: org.h2.Driver jpa: hibernate: ddl-auto: create properties: hibernate: format_sql: true logging.level: org.hibernate.SQL: debug 2. 엔티티를 만들자. @Entity @Getter @Setter public class Member { @Id @GeneratedValue private Long id; private String userName; protected Member() { } public Member(Str..