JPQL 이란 • JPQL은 객체지향 쿼리 언어다.따라서 테이블을 대상으로 쿼리 하는 것이 아니라 엔티티 객체를 대상으로 쿼리한다. • JPQL은 SQL을 추상화해서 특정데이터베이스 SQL에 의존하 지 않는다. • JPQL은 결국 SQL로 변환된다. JPQL 문법 • select m from Member m where m.age > 18 • 엔티티와 속성은 대소문자 구분O (Member, age) • JPQL 키워드는 대소문자 구분X (SELECT, FROM, where) • 엔티티 이름 사용, 테이블 이름이 아님(Member) • 별칭은 필수(m) (as는 생략가능) 집합과 정렬 • GROUP BY, HAVING • ORDER BY select COUNT(m), //회원수 SUM(m.age), //나이..
JAVA/JPA
값 타입 컬렉션 • 값 타입을 하나 이상 저장할 때 사용 • @ElementCollection, @CollectionTable 사용 • 데이터베이스는 컬렉션을 같은 테이블에 저장할 수 없다. • 컬렉션을 저장하기 위한 별도의 테이블이 필요함 - MEMBER @Entity public class Member{ @Id @GeneratedValue @Column(name="MEMBER_ID") private Long id; @Column(name="USERNAME") private String name; @Embedded private Period workPeriod; @Embedded private Address homeAddress; @ElementCollection @CollectionTable(name..
값 타입 • 값 타입: 인스턴스가 달라도 그 안에 값이 같으면 같은 것으로 봐 야 함 • 예) int a = 10; int b = 10; Address a = new Address(“서울시”) Address b = new Address(“서울시”) 값 타입의 비교 • 동일성(identity) 비교: 인스턴스의 참조 값을 비교, == 사용 • 동등성(equivalence) 비교: 인스턴스의 값을 비교, equals() 사용 • 값 타입은 a.equals(b)를 사용해서 동등성 비교를 해야 함 • 값 타입의 equals() 메소드를 적절하게 재정의(주로 모든 필드 사용) - 재정의 @Override public boolean equals(Object o) { if (this == o) return true;..
![](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FcqP2e8%2Fbtq80y8w6qm%2FT8awwKUEkqK5LVosxghYzK%2Fimg.png)
값 타입 값 타입은 복잡한 객체 세상을 조금이라도 단순화하려고 만든 개념이다. 따라서 값 타입은 단순하고 안전하게 다룰 수 있어야 한다. 공유 참조 • 임베디드 타입 같은 값 타입을 여러 엔티티에서 공유하면 위험함 • 부작용(side effect) 발생 Address address = new Address("city","street","10000"); Member member = new Member(); member.setName("member1"); member.setHomeAddress(address); em.persist(member); Member member2 = new Member(); member2.setName("member2"); member2.setHomeAddress(address);..
![](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FbHNqPe%2Fbtq8ZIReEGB%2FwqO6ID18veXF7u2oqm0M30%2Fimg.png)
JPA의 데이터 타입 분류 1) 엔티티 타입 • @Entity로 정의하는 객체 • 데이터가 변해도 식별자로 지속해서 추적 가능 • 예) 회원 엔티티의 키나 나이 값을 변경해도 식별자로 인식 가능 1) 값 타입 • int, Integer, String처럼 단순히 값으로 사용하는 자바 기본 타입이나 객체 • 식별자가 없고 값만 있으므로 변경시 추적 불가 • 예) 숫자 100을 200으로 변경하면 완전히 다른 값으로 대체 값 타입 분류 1) 기본값 타입 • 자바 기본 타입(int, double) • 래퍼 클래스(Integer, Long) • String 2) 임베디드 타입 • embedded type • 복합 값 타입 3) 컬렉션 값 타입 • 컬렉션 값 타입(collection value type) 기본값 타..
![](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FsKd0u%2Fbtq8QqknBmQ%2FnN6CgMeNP9MMQZMeCtHZN0%2Fimg.png)
영속성 전이: CASCADE • 특정 엔티티를 영속 상태로 만들 때 연관된 엔티티도 함께 영속 상태로 만들도 싶을 때 • 예: 부모 엔티티를 저장할 때 자식 엔티티도 함께 저장. 영속성 전이: 저장 - Parent @Entity public class Parent { @Id @GeneratedValue private Long id; private String name; @OneToMany(mappedBy = "parent", cascade = CascadeType.PERSIST) private List childList = new ArrayList(); public void addChild(Child child) { childList.add(child); child.setParent(this); } } ..