인프런 커뮤니티 질문&답변

jwhong1515님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

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

해결된 질문

작성

·

216

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

 

어떻게 해결해야 하나요

답변 4

0

안녕하세요. 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

감사합니다.

jwhong1515님의 프로필 이미지
jwhong1515
질문자

image대략 이렇게 나와요

jwhong1515님의 프로필 이미지
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()

}

 

jwhong1515님의 프로필 이미지
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

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

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

0

jwhong1515님의 프로필 이미지
jwhong1515
질문자

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

0

jwhong1515님의 프로필 이미지
jwhong1515
질문자

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

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

select

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

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

0

안녕하세요, 인프런 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 적용에 대한 보다 구체적인 해결 방안을 위해 위 링크를 참고하실 것을 권장합니다.

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

jwhong1515님의 프로필 이미지
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개 더 뜨는걸로만 바뀌었어요.

jwhong1515님의 프로필 이미지
jwhong1515
질문자

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

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