묻고 답해요
161만명의 커뮤니티!! 함께 토론해봐요.
인프런 TOP Writers
-
해결됨실전! 스프링 데이터 JPA
@Transactional관련 질문 입니다.
package study.querydsl.repository;import org.junit.jupiter.api.AfterEach;import org.junit.jupiter.api.BeforeEach;import org.junit.jupiter.api.Test;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.annotation.Rollback;import org.springframework.transaction.annotation.Transactional;import study.querydsl.entity.Member;import javax.persistence.EntityManager;import javax.persistence.PersistenceContext;import java.util.ArrayList;import java.util.List;@SpringBootTest@Transactional@Rollback(false)class MemberRepositoryTest { @PersistenceContext private EntityManager em; @Autowired private MemberRepository memberRepository; @Test public void test() throws InterruptedException { List<Member> members = makeList(); for (Member member : members) { test1(member.getId()); Thread.sleep(1000); } } private List<Member> makeList() throws InterruptedException { List<Member> members = new ArrayList<>(); for (int i = 0 ; i < 20 ; i++) { Member member = new Member("gon " + i, i); members.add(member); } memberRepository.saveAll(members); em.flush(); //<--- insert query는 생성되나 db 에는 아직 없음. Thread.sleep(5000); return members; } protected void test1(Long id) { Member member = memberRepository.findById(id).get(); member.setUsername("Park"); memberRepository.save(member); em.flush(); //<--- update query는 생성되나 db 에는 아직 없음. }} 안녕하세요 위와 같은 예제에서 makeList 메소드에서 생성된 리스트를 실 db에 insert를 하고 각 리스트 아이템을 처리하는 test1 메소드에서 처리된 아이템을 insert 를 하고 싶은데 em.flush를 해도 insert, update 쿼리만 발생되고 db에는 아직 결과가 들어오지 않고 test가 완전히 종료가 되는 순간 db에 값이 들어온것으로 확인 됩니다. 이를 해결하기 위해서 class에 @transactional 을 제거하고 test1 메소드에 @Transactional을 붙이니 의도한대로 makelist에서 리스트 결과가 한번 db에 저장되고 test1 메소드에서 처리된 결과도 순차적으로 db에 인서트 되는것으로 확인 했으나 연관관계가 존재하는 경우 fetch lazy 동작이 no session으로 안되던데 이를 해결하는 방법이 있는지요. 질문을 정리하면 1. Transactional 중간에 db에 값을 쓰는 방법이 있는지. 2. class에서 @Transactional을 제거 하고 test1에 @Transactional을 붙이면 연관관계 fetch lazy가 동작을 하지 않는 이유가 무엇인지 (제가 이해를 했을땐 test1 부터 영속성 컨텍스트가 관리되어 이후 메소드 호출부터는 transaction이 걸려서 fetch lazy가 동작될거라고 예상했습니다. ) 친절하고 자세한 답변 늘 감사드립니다.
-
미해결자바 ORM 표준 JPA 프로그래밍 - 기본편
일대다 단방향
안녕하세요. 이번 편을 듣고, 일대다 단방향 강의를 다시 들었는데, 거기서, "설계상의 손해를 보더라도 다대일 양방향으로 만들기를 권장한다" 라고 하셨는데, 이번 강의의 경우가 어쩔수 없이 일대다 단방향을 해야하는 경우인가요? 감사합니다.
-
미해결실전! Querydsl
벌크 연산시 flush 호출 여부에 대해 궁금한 점이 있습니다.
안녕하세요. 선생님 벌크연산 강의 중에 질문이 있습니다. JPA 프로그래밍 책에서 JPQL 실행 시 플러시가 자동 호출되어서 영속성 컨텍스트에 있는 쿼리문이 db에 동기화 되는걸로 알고 있는데 벌크 연산은 update 쿼리이기 때문에 자동으로 플러시가 호출되지 않아서 강제로 플러시를 호출해줘야 되는건가요? 이 부분에 혼동이 있어서 질문드립니다.
-
미해결자바 ORM 표준 JPA 프로그래밍 - 기본편
hashCode equals 무한루프 해결 방법문의
안녕하세요 강사님. 동등성 비교를 할 경우 값타입과는 다르게 엔티티의 관계에서는 ManyToOne 과 같은 연결관계가 있는경우 서로가 서로의 equals를 호출하는 경우가 있는데 이를 해결하기 위해 강사님께서 선호하는 방식이 있는지 알고 싶습니다. 저의 생각은 ManyToOne과 같은 비교가 있는경우 그 필드를 제외하는 것이 낫지 않을까 싶었습니다. 이유는 1. 동등성은 @Id로도 충분하지 않을까 하는 생각.2. Team의 동등성을 꼭 체크하지 않아도 Team의 동등성은 Team을 따로 빼서 해도 되지 않을까 (하지만 이것도 생각해보면 Team의 동등성을 따로 검사해야 하나 라는 생각이 듭니다.) 이었습니다. 강사님은 어떻게 생각하시는지 궁금합니다.
-
미해결실전! Querydsl
groupby having절 사용시 fetchCount(), fetchResults() 사용 가능 여부
안녕하세요 도사님 그 동안 JPA 강의 올려주신것 모두 (회사의 지원을 받아)잘 봤습니다. final JPAQuery<Long> countQuery = queryFactory .select(gcm.memberId.count()) .from(gcm) .join(gcm.member, member) .where(member.dropDt.isNull(), gcm.adId.isNotNull(), gcm.adId.isNotEmpty()) .groupBy(gcm.memberId) .having(gcm.adId.count().eq(1L));return PageableExecutionUtils.getPage(content, pageable, () -> countQuery.fetchCount()); return PageableExecutionUtils.getPage(content, pageable, () -> countQuery.fetch().size()); 위 코드는 스프링 JPA를 활용한 QueryDSL 부분에 나오는 도사님의 코드를 참고(복사)하여 만든 코드입니다. 저는 fetchCount()를 사용하고 싶지만 fetchCount()나 fetchResults()를 사용하면 아래와 같은 에러가 발생하여 어쩔 수 없이 fetch()를 사용하고 있습니다. groupby having 절을 사용 할 때만 fetchCount()나 fetchResults()를 사용하면 에러가 발생하는 것 같습니다. Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: unexpected token: having near line 5, column 1 [select count(distinct gcm.memberId) from com.neibus.admin.fcm.repository.Gcm gcm inner join gcm.member as member1 where member1.dropDt is null and gcm.adId is not null and not length(gcm.adId) = 0 having count(gcm.adId) = ?1] 버그인가 싶다가도 이런 버그가 있었다면 강의 내용중에 언급하셨을거라는 생각에 제가 잘못한거라 믿고 도사님께 기대 봅니다. 혹시 제가 잘못한 부분이 있는 건지 아니면 groupby having 절을 사용하면 fetch()만 사용할 수 있는건지 궁금합니다.
-
미해결실전! Querydsl
@DataJpaTest
QueryDsl 강의 잘듣고 있습니다! QueryDsl을 사용하면 @DataJpaTest를 사용하지 못하나요? JPAQueryFactory에 대해서 NoSuchBeanDefinitionException이 발생하는데 따로 주입하는 방법을 모르겠습니다ㅠㅠ
-
해결됨실전! Querydsl
from절의 서브쿼리 해결방안
안녕하세요. from절의 서브쿼리 해결방안으로 애플리케이션에서 쿼리를 두 번 분리해서 실행하라고 하셨는데, 이 말씀이 첫 번째 쿼리로 인라인 뷰에 해당하는 결과리스트를 구하고 이 결과를 두 번째 쿼리의 from절이나 join절에 테이블(뷰) 형식으로 넣을 수 있다는 말씀이신지요?
-
미해결더 자바, 코드를 조작하는 다양한 방법
JVM Memory 메서드 영역과 metadata space 의 차이점
안녕하세요 새해복 많이 받으세요:) 더자바 완강 후 메모리구조에 대해 다시 스터디하고 있습니다. 그러던 중 java8 부터 바뀐 metadata space 에 대해 알게 되었는데요, 힙 영역과 분리되어있고 메타데이터(클래스 이름, 메서드 정보 등)을 담고 있는 걸로 확인했습니다. 더자바 강의에서 메모리의 메서드 영역에 클래스 수준의 정보(풀패키기 경로, 메서드 이름, 변수 명 등)를 담는걸로 학습했던 기억이 있어 두 개념의 차이점을 알고 싶어 질문 남깁니다. 좋은 강의 올려주셔서 감사합니다!
-
해결됨실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
단위 테스트, 통합 테스트에 대한 질문입니다.
안녕하세요. '주문 도메인 개발 - 주문 기능 테스트' 강의 마지막 부분에서 DB와 상관없이 단위 테스트를 해보는 것도 중요하다라고 언급을 해주셨는데요. 강의를 듣고 이해한 단위 테스트라는 것은 JPA를 이용하는 문법(Service, Repository)까지 테스트 하지 않고, 엔티티 클래스(Order, OrderItem 등)에 선언된 비즈니스 로직 메소드만 가지고 잘 동작하는지 테스트 하는것을 의미하는 것인가요? 예를 들어, '주문 상품 재고 감소' 테스트 코드를 작성한다면, 초기값이 설정된 회원과 주문 상품 객체를 생성한 후 주문시 'Service,'와 'Repository'를 사용하지 않고 순수 엔티티 클래스에 정의된 비즈니스 로직 메소드가 잘 동작하는지 확인하는 코드를 작성하면 되는 것 일까요? 위 내용이 맞다면 단위 테스트의 대상은 아래와 같겠네요. OrderItem Class의 createOrderItem(), Order Classs의 createOrder(), Item Abstract Class의 removeStock() 미리 답변 감사드립니다.
-
미해결실전! Querydsl
안녕 하세요
entitymanager는 thread에 safe하지 않는걸로 알고 있습니다 근데 강의에서 thread에 safe하다고 하셔서 확인해보니 safe하지 않네요. spring container가 thread safe하게 관리해주는 것으로 알고 있습니다 맞나요?
-
해결됨자바 ORM 표준 JPA 프로그래밍 - 기본편
영한님! 질문있습니다!
on 대신에 where해도 되지 않나요?!
-
미해결실전 JSP (renew ver.) - 신입 프로그래머를 위한 강좌
강의자료 다운로드가 안됩니다ㅠㅠ
강의자료 다운로드를 눌렀는데 밑의 사진처럼 연결할 수 없다는 화면만 뜨네요. 확인 한번만 부탁드립니다 :)
-
미해결자바 ORM 표준 JPA 프로그래밍 - 기본편
h2 database not found
jpashop 데이터베이스를 찾을 수 없다고 나옵니다. jpashop 말고 test로 하면 연결이 정상적으로 잘 됩니다. 제 생각엔 test.mv.db 파일이 있는거 보니 jpashop.mv.db 파일이 생성되지 않아서 생기는 문제점 같습니다. 이와 같은 문제점을 다른 글에서도 봤지만 해결이 안되었고 몇시간 동안 삽질중입니다... "hello 프로젝트 생성" 이라는 영상에 설명을 해놓으셨다고 하셨는데 어디에 설명이 있는지 들어도 해결이 되지 않습니다 데이터베이스 2개이상 생성은 안되는 건가요??
-
미해결실전! 스프링 데이터 JPA
객체 생성에 대한 방법
안녕하세요? 첫강의부터 쭉 잘 듣고 있습니다. JPA에 대한 질문이라기 보다는 객체지향 기법과 관련된 질문입니다. 엔티티 클래스에 최대한 setter지양하고 필드의 변경 포인트를 해당 엔티티로 모으는 것을 강조하셨고, 객체 생성 시점에 생성자로 필요한 필드들을 다 받아서 생성(저는 of가 더 좋네요)하는 게 좋다고도 말씀하셨지요. 근데 실무 개발하다보면 엔티티에 필드들이 최소 10개 이상은 되고 초반에 세팅되어야 할 값들이 많아지더라구요. 이 상황에서 파라미터가 10개 이상되는 argument constructor나 of를 이용해서 객체를 생성하는게... 맞는가? 예쁜가? 더 좋은 방법은 없는가? 생각이 들더라고요. 클린코드 같은 책보면 파라미터 개수는 3갠가 4개 이하로 유지하는게 좋다고도 하고 가독성도 떨어져 보입니다. 그래서 그냥 default constructor를 public으로 열어두고, setter도 열어둬서 객체 생성을 setAaa, setBbb, setCcc 등으로 해서 하나씩 하게 됩니다. 물론 세팅해줘야할 필드의 누락의 문제나 변경 포인트 관리 어려움 등의 문제가 생기겠지만요. 요약하자면, 생성 시점에 많은 필드들을 이용해 객체를 생성해야 할 때 어떻게 하시는지, 어떻게 하는게 좋을 지 의견 부탁드립니다. 감사합니다.
-
해결됨실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화
orderItem 에 조건을 주려면 어떻게해야하나요?
영한님 안녕하세요~ 주문 조회 V3.1: 엔티티를 DTO로 변환 - 페이징과 한계 돌파 강습을 보고 질문드립니다. 강좌처럼 in 절을 날리면서 데이터를 한번에 가져올때에는 지연로딩을 통해 orderItem 컬렉션을 가져오는데 막상 orderitem에 조건을 주려면 어떻게해야하나요? 애플리케이션(java)에서 작업해야하나요?
-
미해결윤재성의 Java 기반 Android 9.0(pie) App 개발 심화 2단계
SQlight 데이터 베이스 관련 질문 입니다.
안녕하세요. 좋은 강의 잘 보고 있습니다. 하루하루 배우는 재미가 있어서 기분이 좋습니다. 감사합니다. 저는 흔히 말하는 컴맹에 가까운 사람입니다. 자바기초 문법만 조금 알고 있고, db? sql? 아무것도 모르는 상태에서 공부하고 있어서 막히는 부분이 많습니다. 그러다 보니 질문 할게 많이 생기네요.. 혼자 구글링 하면서 알아내고 있는데막히는게 있어서 질문 드립니다. 앱에서 리스트뷰에 입력된 데이터를 검색하는 기능을 추가 하려고 시도 중입니다. 검색한 값의 배열 인덱스를 기억한 배열을 만들어서 반복문을 통해서 검색 해봤는데 잘 작동은 합니다. 그런데 완벽하게 단어를 다 입력해야 검색이 되는 단점이 있어서 단어의 일부만 입력해도 검색이 가능하도록 고민해봤는데요 입력한 단어의 숫자만큼 배열에 있는 모든 값을 일일히 단어 숫자의 개수만큼 차례대로 조합해서 비교 하는 방식으로 코드를 짜 보려고 했는데요. 너무 비효율적이고 느리고 힘들 것 같다는 생각이 들었어요. 거기다가 영문 대소문자 구분부터, 결과내 검색 옵션을 적용 및 항목별 검색까지 적용 하려고 해 보니 머리가 터지려고 하네요. 그래서 구글링 해보면서 SQlite 에 select? 기능을 이용하면 쉽게 검색이 가능할것 같다는 생각이 들었습니다. 배열 값을 일일히 입력해서 그 배열안에서 검색하는 것은 크게 어렵지 않을것 같습니다. 개수가 적으니 속도도 그만큼 빠를 것 같아요. 하지만 db에 입력된 값을 가져와서 배열을 구성하고 다시 그 배열에서 반복문을 통해서 검색을 하려면 느리고 복잡할것 같습니다. 여기서 궁금한점이 생겼습니다. 1. 저장된 db에서 검색된 db를 가져오는 방식은 어떻게 이루어 지나요? 저는 아래 두 방법 정도 있다고 생각했는데요. 혹시 잘못 알고 있는지 궁금합니다. 1) db에서 필요한 db를 검색해서 -> db에서 데이터를 갖고와서 db배열을 만든다->그 배열을 리스트 뷰에 입력한다. 2) 처음 앱이 시작하면 db를 전부 항목별로 가져와서 배열에 입력한다.->그 배열에서 검색한 후 ->리스트뷰에 입력한다. 2.앱에 있는 검색 창(EditText)에 서 가져온 값을 자바에 입력된 배열과 배교할 필요없이 곧바로 SQlite 을 통해서 db파일에서 검색이 가능한가요? 3.혹시 앱에 검색기능을 추가하기 위해서 데이터베이스 공부가 필요하다면 추천 커퓨니티나 도서가 있을까요?
-
미해결예제로 배우는 스프링 입문 (개정판)
필드에 @Autowired 후 maven package 또는 build 에러
생성자에서 빈 객체 주입 하던 방식에서 필드에 직접 @Autowired 어노테이션을 붙여서 하는 방식으로 바꾸고 maven package 또는 build 할때 "spring Formatting violations found in the following files:" 위 에러 메세지가 뜨면서 exit(1)이 발생하는 경우가 있습니다. 찾아보니 스프링 관련 문법(?)을 어겼다고 규칙에 맞는 문법으로 수정하라는 오류메세지인데, 빈 객체에서는 생성자를 통해 빈 객체를 주입받는 문법만 허용해서 발생하는 오류입니다."mvnw spring-javaformat:apply" 위 명령어를 통해 스프링에서 허용하는 문법을 적용하여 해결하실 수 있습니다.
-
미해결실전! 스프링 데이터 JPA
enum을 list로 어떻게 받는지 궁금합니다.
import lombok.Getter;import lombok.RequiredArgsConstructor;@Getter@RequiredArgsConstructorpublic enum RoleType { USER("user","일반 유저"), ADMIN("admin","관리자"); private final String roleCode; private final String roleName;}이렇게 롤 타입이 있고, 이것을 유저에 매핑하면 @Enumerated(value = EnumType.STRING)@Column(nullable = false)private RoleType roleType;보통 이런식으로 사용이 되는데전 RoleType을 복수로 List<RoleType>로 갖게 하고 싶은데 이럴 땐 어떻게 하는지 궁금합니다.p/s 다음 강의는 언제쯤 나올까여? ㅎㅎ querydsl기대중입니다!
-
미해결더 자바, 코드를 조작하는 다양한 방법
강의자료에서 링크의 Resolve 내용에 대한 질문입니다.
현재 링크의 Resolve 설명에서 `심볼릭 메모리 레퍼런스를 메소드 영역에 있는 실제 레퍼런스로 교체한다.`라고 명시되어 있습니다. 메소드 영역은 클래스 정보만을 저장하는 영역이라 알고 있어서 메소드 영역이 아니고 힙 영역이라고 맞다고 생각이 드는데, 이것이 맞는지 궁금합니다.
-
미해결실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
H2 MVCC에 관해서
url: jdbc:h2:tcp://localhost/~/jpashop;MVCC=TRUE application.yml에서 강의와 동일하게 위와 같이 작성하였습니다. 그런데 org.h2.jdbc.JdbcSQLNonTransientConnectionException: Unsupported connection setting "MVCC" [90113-200] 위와같은 에러가 나서 아래와 같이 작성하여 테스트를 재실행해보니 에러가 사라졌습니다. url: jdbc:h2:tcp://localhost/~/jpashop MVCC설정이 안되는 이유를 좀 알려주시면 감사하겠습니다.