작성
·
109
0
강의에서 값 타입 컬렉션은 모든 컬럼이 기본키가 되기 때문에 중복저장이 되지 않는다고 하셨는데 중복 저장이 가능하여 문의 드립니다.
public static void main(String[] args) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
EntityManager em = emf.createEntityManager();
EntityTransaction tx = em.getTransaction();
tx.begin();
try {
Address address = new Address("city", "street", "1");
Member member = new Member();
member.setUsername("member1");
member.setWorkAddress(address);
member.getFavoriteFoods().add("치킨");
member.getFavoriteFoods().add("피자");
member.getAddressHistory().add(address);
member.getAddressHistory().add(address);
em.persist(member);
em.flush();
em.clear();
System.out.println("=====================");
Member findMember = em.find(Member.class, member.getId());
List<Address> addressHistory = findMember.getAddressHistory();
addressHistory.forEach(Address::getCity);
Set<String> favoriteFoods = findMember.getFavoriteFoods();
favoriteFoods.forEach(System.out::println);
findMember.setHomeAddress(new Address("newCity", address.getStreet(), address.getZipcode()));
// 치킨 -> 한식
findMember.getFavoriteFoods().remove("치킨");
findMember.getFavoriteFoods().add("한식");
// 주소 변경
findMember.getAddressHistory().remove(new Address("city", "street", "1"));
findMember.getAddressHistory().add(new Address("newcity", "new", "100"));
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
} finally {
em.close();
}
emf.close();
}
답변 1
0
안녕하세요. sss3598님
JPA가 테이블을 생성할 때 값 타입 테이블에 PK를 잡아주지 않아서 데이터를 중복해서 넣을 수 있는데요.
보통 이런 경우 PK를 수동으로 직접 잡아주셔야 합니다.
PK를 수동으로 잡아주면 중복으로 저장할 수 없게 됩니다.
감사합니다.