[Spring Introduction] 6. 스프링 DB 접근 기술 (H2 DB)

윤경·2021년 10월 5일
0

Spring Boot

목록 보기
38/79
post-custom-banner

[1] H2 데이터베이스 설치

H2 설치하기

잘 안 되는 경우는 이렇게 url을 수정해주기

잘 안된다 싶으면 일단 DB 나가서 콘솔에서 rm 명령어로 파일 지우고, h2 서버도 껐다 키고 다시 해보기

binint = long


[2] 순수 JDBC

화석 개발자분들,,^^이 고생하신 부분이라 편안하게 들으라고 하셔서 그냥 패쓰하도록 하겠습니다 '^'


[3] 스프링 통합 테스트

@SpringBootTest: 스프링 컨테이너와 테스트를 함께 실행

@Transactional: 테스트 케이스에 이 애노테이션이 있으면 테스트 시작 전 트랜잭션을 시작하고 테스트 완료 후 항상 롤백한다.
이렇게하면 DB에 데이터가 남지 않으므로 다음 테스트에 영향을 주지 않는다.


[4] 스프링 JdbcTemplate


[5] JPA

JPA는 기존 반복 코드는 물론, 기본적인 SQL도 JPA가 직접 만들어 실행해줘 개발 생산성을 크게 높일 수 있다.
또한, SQL과 데이터 중심의 설계에서 객체 중심의 설계로 패러다임을 전환할 수 있다.

show-sql: JPA가 생성하는 SQL을 출력
ddl-auto: JPA는 테이블을 자동으로 생성하는 기능을 제공. none을 사용하면 해당 기능을 끔. create를 사용하면 엔티티 정보를 바탕으로 테이블도 직접 생성해줌.

control + T: 인라인 같은거 검색해서 바로바로 적용할 수 있음 (mac)

스프링은 해당 클래스 메소드를 실행할 때 트랜잭션을 시작하고, 메소드가 정상 종료되면 트랜잭션을 커밋한다. 만약 런타임 예외가 발생하면 롤백한다.

JPA를 통한 모든 데이터 변경은 트랜잭션 안에서 실행해야 한다.


[6] 스프링 데이터 JPA

스프링 데이터 JPA는 리포지토리에 구현 클래스 없이 인터페이스 만으로 개발할 수 있다. 그리고 반복 개발해온 기본 CRUD 기능도 스프링 데이터 JPA가 제공한다.
➡️ 반복 코드가 줄어든다.

스프링 데이터 JPA 제공 기능

  • 인터페이스를 통한 기본적인 CRUD
  • findByName(), findByEmail()처럼 메소드 이름 만으로 조회 기능 제공
  • 페이징 기능 자동 제공

profile
개발 바보 이사 중
post-custom-banner

0개의 댓글