dev/spring JPA 활용 웹만들기
jpa 와 db 연동하기
dev_0hoon
2024. 1. 2. 17:43
먼저 properties가 아닌 yml 파일을 사용한다.
spring: #띄어쓰기 없음
datasource: #띄어쓰기 2칸
url: jdbc:h2:tcp://localhost/~/jpashop #4칸
username: sa
password:
driver-class-name: org.h2.Driver
jpa: #띄어쓰기 2칸
hibernate: #띄어쓰기 4칸
ddl-auto: create #띄어쓰기 6칸
properties: #띄어쓰기 4칸
hibernate: #띄어쓰기 6칸
#show_sql: true #띄어쓰기 8칸
format_sql: true #띄어쓰기 8칸
logging.level: #띄어쓰기 없음
org.hibernate.SQL: debug #띄어쓰기 2칸
org.hibernate.type: trace #띄어쓰기 2칸
마지막 org.hibernamte.type은 sql 파라미터를 볼 때에 사용한다.
그 외에도 build.gradle에서
plugins {
id 'java'
id 'org.springframework.boot' version '3.2.1'
id 'io.spring.dependency-management' version '1.1.4'
}
group = 'jpabook2'
version = '0.0.1-SNAPSHOT'
java {
sourceCompatibility = '17'
}
configurations {
compileOnly {
extendsFrom annotationProcessor
}
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
implementation 'org.springframework.boot:spring-boot-starter-thymeleaf'
implementation 'org.springframework.boot:spring-boot-starter-web'
implementation 'junit:junit:4.13.1'
implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.9.0' //로그에 sql 파라미터 남기기
compileOnly 'org.projectlombok:lombok'
runtimeOnly 'com.h2database:h2'
annotationProcessor 'org.projectlombok:lombok'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
//JUnit4 추가
testImplementation("org.junit.vintage:junit-vintage-engine") {
exclude group: "org.hamcrest", module: "hamcrest-core"
}
}
tasks.named('test') {
useJUnitPlatform()
}
implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.9.0' //로그에 sql 파라미터 남기기
이 부분이 sql 파라미터 값을 볼 수 있게 한다.
package jpabook2.jpashop2;
import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.Id;
import lombok.Getter;
import lombok.Setter;
@Entity
@Getter @Setter
public class Member {
@Id @GeneratedValue
private Long id;
private String username;
}
dto를 생성하고
package jpabook2.jpashop2;
import jakarta.persistence.Entity;
import jakarta.persistence.EntityManager;
import jakarta.persistence.PersistenceContext;
import org.springframework.stereotype.Repository;
@Repository
public class MemberRepository {
@PersistenceContext //자동 엔티티 생성
private EntityManager em;
//shift + command + t는 테스트코드 단축키
public Long save(Member member){
em.persist(member);
return member.getId();
}
public Member find(Long id){
return em.find(Member.class,id);
}
}
Repository를 생성해주는데, jpa 문법 한가득이다. 공부해야 할게 많다.
package jpabook2.jpashop2;
import org.assertj.core.api.Assertions;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.annotation.Rollback;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.transaction.annotation.Transactional;
import static org.junit.Assert.*;
@RunWith(SpringRunner.class)
@SpringBootTest
public class MemberRepositoryTest {
@Autowired MemberRepository memberRepository;
@Test //테스트가 끝나면 다 롤백 된다. 오류만 안나면 된다.
@Transactional
@Rollback(false) //롤백 안나게 하기
public void testMember() throws Exception{
//given
Member member = new Member();
member.setUsername("홍길동");
//when
Long saveId = memberRepository.save(member);
Member findMember = memberRepository.find(saveId);
//then
Assertions.assertThat(findMember.getId()).isEqualTo(member.getId());
Assertions.assertThat(findMember.getUsername()).isEqualTo(member.getUsername());
Assertions.assertThat(findMember).isEqualTo(member); //같은 곳에 있는 영속성 틀래스의 경우 같은 것으로 인지 한다. 캐쉬 안에 같은 것으로 받아들이게 된다.
}
}
마지막으로 테스트 코드를 작성했고 모두 초록색 불이 떴다.
데이터도 잘 들어왔고 연결 성공이다.