no image
[GIT] 특정 시점에서의 변경 내역만 되돌리기
회사에서 다른 분이 작업했었던 브랜치가 master 에 병합이 되었는데 적용하지 말아야 하는 경우가 생겨서 이미 다른 사람들까지 병합이 된 상황에서 되돌려야 하는 경우가 생겼다. $ git log --oneline --graph * f82c9d2 (HEAD -> master, tag: v1.16.7o, origin/master, origin/HEAD) Merge branch 'hotfix/EMTT-350' into 'master' |\ | * cf2113f (origin/hotfix/EMTT-350, hotfix/EMTT-350) feat: cache key 확인 후 없으면 api 호출하도록 수정 | * adb8f11 refact: 인자 수정 | * e1653bd refact: isset 은 null 확..
2023.09.14
no image
[Spring] RestTemplate 과 MessageConverter 사이의 Converter 순서 이슈
계기회사에서 내가 만들어둔 라이브러리를 다른 팀에서 사용하고 있는 경우가 있었는데, 어느 날 갑자기 다른 팀에서 아래와 같은 메세지가 나타난다고 확인 요청이 왔다.java.lang.IllegalStateException: org.springframework.web.client.HttpClientErrorException$BadRequest: 400 Bad Request: "{"errors":["failed to parse JSON input: invalid character '\u003c' looking for beginning of value"]}"이게 갑자기 나타날리가 없어서 어떤 작업을 한 후에 나타났냐고 물으니, build.gradle 에 아래와 같은 의존성을 추가하면 위와 같은 에러가 나타난다고..
2023.02.05
no image
[Spring] 컬럼이 많은 상황에서 Reflection 시 ConversionService 활용해보기
배경회사에서 100개가 넘는 컬럼들을 다루어야 하는 경우가 있었다.100개가 넘는 컬럼들 중 섹션별로 일부의 데이터를 추가하거나 수정할 수 있어야 했고, 기존의 데이터와 서로 다른지 판단할 수 있어야 하며 이를 로그로도 남겨야 하는 요구사항이 있었다. 예를 들면 Entity 가 아래와 같은데, @ExampleSection 이라는 Annotation 으로 섹션을 분리한 뒤 사용자가 원하는 Section 별로 데이터를 저장하거나 수정할 수 있어야 하는 것이다.@Entity(name = "exampleEntity")@Table(name = "EXAMPLE_ENTITY", schema = "GREATSCHEMA")@DynamicInsert @DynamicUpdate@Builder@Getter@NoArgsCons..
2022.11.21
no image
[Spring] AutoConfiguration 직접 만들어서 라이브러리로 만들어보기
Spring 에서는 상당히 많은 AutoConfiguration 을 제공해주고 있는데, 따로 라이브러리를 만들면서 직접 만들 수도 있다.테스트로 하나 만들어보자 구성우선 구조는 아래처럼 잡고 멀티모듈로 구성했다.autoconfigure - Spring Boot 에서 자동으로 AutoConfiguration 이 적용되는 로직 관련somelogic - 비즈니스 로직// root - build.gradlebuildscript { ext { projectVersion = '1.0.0' projectGroup = 'kr.pe.karsei' springBootVersion = '2.7.5' springDependencyVersion = '1.0.15.RELEA..
2022.11.11
no image
[JPA] QueryDSL에서 오늘 날짜 활용해서 사용하기 (feat. Oracle)
아래와 같은 클래스가 있다.@Entity@Builder@Getter@NoArgsConstructor @AllArgsConstructorpublic class PremiumPrice { @Id private Long id; @Column private BigDecimal usdPrice; @Column @CreationTimestamp private LocalDateTime registDate;}만약, 데이터를 찾을 때 registDate 를 기준으로 오늘 이후의 데이터를 찾고 싶으면 어떻게 할까?여러 가지 방법이 있겠지만 이 글에서는 두 가지 방법을 소개한다. Expressions.dateTemplateExpressions.dateTemplate(LocalDateTi..
2022.10.24
no image
[JPA] QueryDSL에서 문자열을 숫자로 뽑아서 변환하기
Entity 안에서 String 으로 관리되고 있는 값을 다른 DTO 클래스에서 받을 때 BigDecimal 과 같은 데이터 타입으로 받고 싶다면 어떻게 할까?물론, Entity 안에 있는 필드 데이터 타입과 똑같이 관리되면 좋겠지만 뭔가 크롤러 같은 프로그램에서 어딘가의 가격 데이터를 가져올 때 아래와 같은 데이터들이 포함된다고 해보자. '판매중이지 않음''1200000''없음' 만약, 위 데이터 중에서 숫자만 이루어진 것을 뽑아내려면 어떻게 해야 할까? 충분히 있을 수 있는 상황이다. 우선 아래와 같은 클래스가 있다고 하고, renewalPrice 라는 필드 값에 위와 같은 데이터들이 포함된다고 생각해보자@Builder@Getter@NoArgsConstructor @AllArgsConstructorp..
2022.10.24
[ERROR] prepareKotlinBuildScriptModel Task fails in a Java project
문제 원인 :prepareKotlinBuildScriptModel Task fails in a Java project 해결 방안 build.gradle 에 아래와 같은 코드를 넣어준다. tasks.register("prepareKotlinBuildScriptModel"){} IDEA Kotlin 플러그인이 해당 Task 를 실행시키면서 발생하는 것 같은데 원래는 Root 프로젝트에 있을 경우에만 진행되는 것 같다. 멀티모듈 연결이나 다른 작업이 일어나면서 어디선가 꼬이면서 일어나는 것 같다. 참고: https://github.com/gradle/gradle/issues/14889
2022.10.19
[JPA] Oracle 을 사용해서 Native Query 로 출력 개수까지 다 가져와보기
예를 들어, 아래와 같은 복잡한 질의가 있다. SELECT so.seqno , ... , CASE WHEN SYSDATE BETWEEN MIN(ev.startdate) AND MIN(ev.enddate) THEN 'Y' ELSE 'N' END AS event_flag , TO_CHAR(MIN(so.display_start), 'yyyy-mm-dd hh24:mi') AS display_start , TO_CHAR(MAX(so.display_end), 'yyyy-mm-dd hh24:mi') AS display_end , TO_CHAR(MIN(ev.startdate), 'yyyy-mm-dd hh24:mi') AS event_start_date , TO_CHAR(MAX(ev.enddate), 'yyyy-mm-d..
2022.10.17
no image
[Spring] 라이브러리 등록 시 라이브러리를 외부에서 소스를 볼 수 있도록 하기
예를 들어, Intellij 에서 직접 External Libraries 또는 어떤 객체의 사용 위치를 참조하여 파일을 살펴볼 때 아래와 비슷하게 메세지가 나타나는 경우가 있다. Decompiled .class file, bytecode version: 57.0 (Java 13) 보통 개발을 하면서 문제가 생겼을 때 디버깅을 찍어보면서 Spring 과 같은 다른 라이브러리의 내부 코드를 들여다보던지 아니면 평소대로 라이브러리에서 지원하는 메서드를 사용하려고 할 때 주석이라던지를 참조를 하게 되는데 자기가 직접 스스로 라이브러리를 만들면서 Maven 또는 직접 운영하는 Nexus 에 라이브러리를 등록하여 사용을 할 때 만약 아무런 빌드 옵션을 주지 않고 등록을 하게 되면 위와 같이 바이트 코드만 볼 수 있..
2022.10.13