일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- MySqlType
- JPAmapping
- spring
- springbootproxy
- sql
- 스프링부트
- 자바제너릭
- 임베디드타입
- 데이터베이트h2
- httppie
- JPAproxy
- springbootH2
- JPA Hint & Lock
- Open EntityManager
- Git
- 스프링부트기본설정
- springboot기본설정
- JDBC connection pool
- 제이피큐엘쿼리
- 에이치투데이터베이스
- OSIV
- JPA값타입
- embededtype
- javageneric
- jpa
- JPA프록시
- gitinitial
- dockercmd
- jpqlquery
- 이해와 원리
Archives
- Today
- Total
빡코
[JPA] 스프링데이터 JPA - 트랜잭션 본문
Transaction? 쪼갤 수 없는 단위로 한번에 성공 또는 실패하는 것을 의미 한다.
시작: start transaction
완료: commit
실패처리: rollback
영속성 컨텍스트? 테이블과 매핑된 Entity 객체를 관리/보관하는 역할
1. 변경감지(Dirty Check): 영속성 컨텍스트 안에서 불러와진 Entity는 명시적으로 save 를 해주지 않더라도 알아서 변경을 감지하여 저장
2. 쓰기지연: 트랜잭션이 commit 되는 시점에 SQL을 한번에 모아서 DB에 반영한다.
3. 1차 캐싱: entity의 Id를 기준으로 기억하는 기능, 같은 Id로 조회시 총 1번의 select 쿼리만 날라간다.
'Java > JPA' 카테고리의 다른 글
[JPA] 스프링데이터 JPA (0) | 2023.12.27 |
---|---|
[querydsl] 스프링부트 3.0 + java 17 build.gradle 설정 파일 (0) | 2023.05.31 |
[스프링데이터JPA] 새로운 엔티티(Entity)를 구별하는 방법 (0) | 2023.05.12 |
[스프링데이터JPA] 스프링테이터 JPA 분석 (0) | 2023.05.12 |
[스프링데이터 JPA] Web 확장 - 도메인클래스컨버터, 페이징과 정렬 (0) | 2023.05.12 |