
JPQL 타입 표현 예시들 MemberType public enum MemberType { ADMIN, USER } Member에 필드로 추가 @Enumerated(EnumType.STRING) private MemberType type; JpqlMain 수정 public class JpqlMain { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); tx.begin(); try { Tea..

조인 - ON 절 1. 조인 대상 필터링 예제 JpqlMain public class JpqlMain { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); tx.begin(); try { // 팀 먼저 저장 Team team = new Team(); team.setName("TeamA"); em.persist(team); Member member = new Member(); member.s..

조인 SQL의 조인과 양상은 비슷하나 얘는 엔티티 중심으로 동작한다. 약간 객체 스타일로 조인 문법이 나간다. 연관있는 것을 . 으로 표현한다. 간단히 복기하고 넘어가면 내부조인은 값이 없으면 그대로 안 나오지만, 외부조인은 한쪽의 값이라도 있으면 없는 쪽은 빠진 채로 출력됨. 예제 Member에 Team getter, setter 먼저 추가 후, Team에도 Member의 getter, setter 추가 후 작업 Member에 Lazy로 전략 명기 @ManyToOne(fetch = FetchType.LAZY) // 중요. @JoinColumn(name = "TEAM_ID") private Team team; Member - 연관관계 편의 메서드 추가 public void changeTeam(Team t..

페이징 API order by 가 꼭 들어가야 Sorting이 되면서 페이징이 제대로 되는지 확인 가능하므로 중요하다. 예제 일단 귀찮으니 Member에 toString() 만들고 시작. @Override public String toString() { return "Member{" + "id=" + id + ", username='" + username + '\'' + ", age=" + age + '}'; } JpaMain public class JpqlMain { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em..

프로젝션 1. SELECT m FROM MEMBER m -> 엔티티 프로젝션 JpqlMain public class JpqlMain { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); tx.begin(); try { Member member = new Member(); member.setUsername("member1"); member.setAge(10); em.persist(member..

JPA는 다양한 쿼리 방법을 지원 JPQL 소개 JPQL 예시 JPAMAIN public class JpaMain { public static void main(String[] args) { EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello"); EntityManager em = emf.createEntityManager(); EntityTransaction tx = em.getTransaction(); tx.begin(); try { List result = em.createQuery( "select m from Member m where m.username like '%kim% '", Member.class) .getRe..