save 메서드 질문드립니다.
258
4 asked
만약에 id 값과 변경할 파라미터를 받아서 update를 하고 싶을 경우는
파라미터에서 넘어오는 id로
Optional<Post> post = repository.findById(id);
Post postUpdate = repository.save(post.get());
postUpdate.setTitle(파라미터);
이런 방법을 사용해야하는건가요?
//아래 두개의 파라미터는 객채로 받음.
id랑 변경할 컬럼을 파라미터로 보내고
Post postUpdate = repository.save(post);
이런식으로 save를 하면 다른 컬럼들은 전부 null로 변경이 되는데 이럴 경우는 제가 첫번째에 코드처럼 작성하여 update를 진행하는게 맞는 방법인지 궁금하여 문의 드립니다.
Answer 1
0
안녕하세요. 순서가 조금 이상한데요.
조회(get) -> 수정(set) -> 저장(save) 이 순서가 자연스러운 순서인데요. 말씀하시는 문제가 그 순서 때문에 발생한 문제는 아닌것 같고 트랜잭션이 없는 상태에서 save를 시도한게 아닌가 싶네요. 저 코드가 전부 트랜잭션 안에서 실행되는 코드가 맞나요?
0
답변 감사합니다.
제가 질문을 좀 난해 하게 한것같습니다.
제가 여쭈어 보고 싶은건
Post의 id는 알고 있는데 만약에 update 할때 title만 변경을 하고 싶을 경우
파라미터로 받은 id를 가지고 레포지터리에서 엔티티를 조회 후
해당 엔티티의 setTitle("변경할 타이틀") 후 save를 호출을 해야하나 해서요!
굳이 아이디를 아는데 findById를 해서 데이터를 조회 해와서가 아닌
바로 title만 변경하는 쿼리를 발생 시킬 순 없나 해서 질문을 남겼습니다.
그런데 수업을 듣다보니 영속성과 관련이 있고 객체지향적으로 하려다 보니 어쩔수 없는 부분이다
라고 생각이 드네요.... 혹시 더 나은 방법이 있나요??
요약 하자면 id만 가지고 find 하지 안고 바로 update 만 할 수 없나? 라는 궁금점이 생겨서 질문 남겼습니다!. 감사합니다!
spring boot 2.7.13-SNAPSHOT trace 소문자 로그 안나옴
0
533
1
<스프링 데이터 Common: 기본 리포지토리 커스터마이징> 에 대한 질문
0
392
1
comment table에서 저장될떄 왜 id값이 2부터저장이되는건가요?
0
407
1
@EnableJpaRepositories 설정을 스프링부트가 어디에서 자동설정하나요?
0
450
0
PersistenceContext 관련 질문드립니다.
0
335
1
지금(Eager), 나중에(Lazy)의 의미를 모르겠습니다
0
338
1
transaction 구간이 길어질 경우의 처리방법 문의드립니다.
0
905
1
docker postgres
0
293
1
Multiple DataSource 사용 시 transaction 관련 질문 드립니다.
0
2908
1
entity 중 null이 아닌 필드만 update 할 방법이 있을까요?
0
1190
1
Eager 모드일 경우, join을 inner join으로 바꾸는 법이 있을까요?
0
385
1
엔티티를 상속받는 DTO가 일반적인가요?
1
1847
1
커스텀 타입 클래스를 String 타입 처럼 이용해 쿼리하는 방법에 대해 질문하고 싶습니다.
0
339
1
연관관계 매핑 어떤식으로 해야될지 감이 안잡힙니다.
0
566
4
EntityManager 주입시 Annotation관련 질문드립니다.
0
565
1
클래스 기반 프로젝션 사용 관련 질문
0
560
1
복잡한 통계쿼리도 JPA로 가능한가요?
2
5592
1
find 와 get의 차이가 무엇인가요?
0
890
1
실무에서 JPA 할 때 FK로 개발할때 연관관계를 꼭 맺어주어야 하나요?
0
998
1
\dt Did not find any relations.
0
481
1
소스코드는 어디서 볼 수 있을까요?
1
287
1
table 생성과 select 문에 대한 질문
0
174
1
스프링 데이터 RepositoryTest 관련 질문
0
2173
2
NoRepositoryBean 과 추상클래스
0
446
1

