inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Trong thực tế! Sử dụng Spring Boot và JPA1 - Phát triển ứng dụng Web

JPA와 DB 설정, 동작확인 강의영상에서

Đã giải quyết

370

jwhong1515

8 câu hỏi đã được viết

0

쿼리 파라미터 로그 남기기 - 스프링 부트 3.0

스프링 부트 3.0 이상을 사용하면 라이브러리 버전을 1.9.0 이상을 사용해야 한다. ```

implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.9.0'

 

이거 했는데

 

퀴리부분이 이렇게 짤려서 나오는데

select

next value for member_seq

 

어떻게 해결해야 하나요

java spring 웹앱 spring-boot jpa

Câu trả lời 4

0

OMG

안녕하세요. jwhong1515님, 공식 서포터즈 OMG입니다.

select

next value for member_seq

이 내용은 아래의 1~2번 줄 같이 출력되고 있는 상황을 얘기하신 것같아요.

yml 설정의 format_sql = true로 되어 있어서 포맷팅되어 출력합니다.

그리고 p6spy에 대해서는 테스트 실행 시[Test worker] p6spy라는 문구가 출력되지 않고 있을까요?

그리고 실제로 값이 바인딩 되는 것을 보려면 (? , ?, ?) 혹은 where id = ?

실제 값이 ? 대신 들어갈 수 있을 쿼리 가령 INSERT 쿼리select where = 쿼리로 확인을 해보셔야 할 . 것같습니다.

올려주신 내용만으로는 어떤 오류나 상황인지 더 이상의 확인은 어려워서 발생하는 상황을 캡쳐,설명 build.gradle 전체를 복사하여 알려주시겠어요?

image

감사합니다.

0

jwhong1515

image대략 이렇게 나와요

0

jwhong1515

plugins {

id 'java'

id 'org.springframework.boot' version '3.2.1'

id 'io.spring.dependency-management' version '1.1.5'

}

group = 'jpabook'

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-validation'

implementation 'org.springframework.boot:spring-boot-starter-web'

implementation 'org.springframework.boot:spring-boot-devtools'

// implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.9.0'

compileOnly 'org.projectlombok:lombok'

runtimeOnly 'com.h2database:h2'

annotationProcessor 'org.projectlombok:lombok'

testImplementation 'org.springframework.boot:spring-boot-starter-test'

testRuntimeOnly 'org.junit.platform:junit-platform-launcher'

//JUnit4 추가

testImplementation("org.junit.vintage:junit-vintage-engine") {

exclude group: "org.hamcrest", module: "hamcrest-core"

}

}

tasks.named('test') {

useJUnitPlatform()

}

 

0

jwhong1515

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.orm.jdbc.bind: trace

0

OMG

// implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.9.0'

주석처리가 되서 안됐었나보네요 😀

0

jwhong1515

아예 ?로도 안나와서 로그확인이 어려운 것 같아요. ㅠㅠ

0

jwhong1515

// implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.9.0'

이 부분을 주석으로 처리하고 gradle 새로고침해도

select

next value for member_seq 이렇게만 나오는데,

implementation한 것을 지우고 새로고침하면 이미 다운받은 파일은 삭제가 안 되는 건가요?

0

jwhong1515

처음에는 로그가 아예 안 나와서

https://www.inflearn.com/questions/902500/%EB%A1%9C%EA%B7%B8%EA%B0%80-%EA%B0%91%EC%9E%90%EA%B8%B0-%EC%95%88%EB%82%98%EC%98%B5%EB%8B%88%EB%8B%A4-%E3%85%A0%E3%85%A0%E3%85%A0%E3%85%A0

이거 했거든요. 이게 문제가 될까요?

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

질문 내용을 토대로 스프링 부트 3.0 버전 이상에서 JPA 쿼리 파라미터 로그 남기기와 관련된 문제를 해결하고자 라이브러리 p6spy-spring-boot-starter 버전을 1.9.0으로 업그레이드 했음에도 불구하고 쿼리 부분이 제대로 출력되지 않는 상황으로 이해했습니다.

유사한 상황을 해결한 기존의 답변을 찾았습니다. 스프링 부트 버전 업데이트 후 p6spy를 적용할 때 발생할 수 있는 이슈와 관련하여, spring boot 3.0.0 에서 p6spy 적용이 안됩니다. 에 공유된 해결책을 참조해 보시는 것을 추천합니다. 이 질문에서는 스프링 부트 3.0을 사용하면서 p6spy 적용에 어려움을 겪는 상황을 다루고 있으며, 추가적인 설정 방법을 제안하고 있습니다.

하지만, 질문자님이 제시한 문제는 쿼리 결과가 부분적으로 출력되는 것과 관련이 있어, p6spy 적용 방법 외에도, 쿼리 로깅 세부 설정이나 H2 데이터베이스 설정(예: spring.datasource.hikari.data-source-properties.cachePrepStmts, spring.datasource.hikari.data-source-properties.prepStmtCacheSize 등) 검토가 필요할 수 있습니다.

질문 내용에 정확히 일치하는 답변을 제공하기는 어려웠지만, p6spy 적용에 대한 보다 구체적인 해결 방안을 위해 위 링크를 참고하실 것을 권장합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

0

jwhong1515

select

next value for member_seq

04:59:50.978 [main] INFO p6spy -- #1717185590978 | took 11ms | statement | connection 3| url jdbc:h2:tcp://localhost/~/jpashop

select next value for member_seq

select next value for member_seq;

 

이렇게 밑에 2개 더 뜨는걸로만 바뀌었어요.

0

jwhong1515

OpenJDK 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended

이 오류도 뜨는데, 이것때문에 영향이 있는 건가요?

sdk 설정 오류

0

50

2

오탈자 - @Transactional

0

55

1

src/test/resources 테스트 경로 문제

0

50

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

64

1

MemberRepositoryTest 실행오류

0

81

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

183

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

137

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

51

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

71

1

기본 생성자

0

60

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

100

1

멤버서비스테스트 부분에서 막힙니다.

0

164

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

116

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

118

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

113

1

24분 27초 연관관계 편의 메서드 위치

0

113

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

108

2

빌드 툴, Gradle

0

59

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

76

2

Repository에서 EntityManager 주입 방식 차이

0

88

1

롬복과 사용자 정의 setter 메서드

0

71

1

주문 목록 조회 fetch join 질문드립니다

0

81

1

dirty checking 질문드립니다.

0

81

1

동시성 관련 질문입니다

0

74

1