본문 바로가기

java

(77)
QueryDsl를 활용하여 DTO로 바로 만들기 query를 통해서 Entity 값을 가져온 후 DTO로 converter하는 과정이 매우 번거롭다. Querydsl를 통해서 한 번에 DTO로 만들어보자 @Getter @Setter @NoArgsConstructor @AllArgsConstructor public class ChartInfo { private Long msgRate; private Long totalRate; private Long pendMsgRate; } 위와 같은 DTO가 있고, chart라는 DB가 있다고 가정한다. private JPAQueryFactory queryFactory; List charInfo = queryFactory.select( Projections.bean(ChartInfo.class, chart.msgRa..
[프로그래머스/Java] 피보나치 수 📚 피보나치 수 [JAVA] 프로그래머스 Level 2. 코딩테스트 연습 - 피보나치 수 | 프로그래머스 스쿨 (programmers.co.kr) 문제 피보나치 수는 F(0) = 0, F(1) = 1일 때, 1 이상의 n에 대하여 F(n) = F(n-1) + F(n-2) 가 적용되는 수 입니다. 예를들어 F(2) = F(0) + F(1) = 0 + 1 = 1 F(3) = F(1) + F(2) = 1 + 1 = 2 F(4) = F(2) + F(3) = 1 + 2 = 3 F(5) = F(3) + F(4) = 2 + 3 = 5 와 같이 이어집니다. 2 이상의 n이 입력되었을 때, n번째 피보나치 수를 1234567으로 나눈 나머지를 리턴하는 함수, solution을 완성해 주세요. 제한사항 • n은 2 이상 ..
[프로그래머스/Java] 다음 큰 숫자 📚 다음 큰 숫자 [JAVA] 프로그래머스 Level 2. 코딩테스트 연습 - 다음 큰 숫자 | 프로그래머스 스쿨 (programmers.co.kr) 문제 자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다. 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다. 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니다. 조건 3. n의 다음 큰 숫자는 조건 1, 2를 만족하는 수 중 가장 작은 수 입니다. 예를 들어서 78(1001110)의 다음 큰 숫자는 83(1010011)입니다. 자연수 n이 매개변수로 주어질 때, n의 다음 큰 숫자를 return 하는 solution 함수를 완성해주세요. 제한사항 • n은 1,000,000 이하의 자연수 입니다. ..
[프로그래머스/Java] 숫자의 표현 📚 숫자의 표현 [JAVA] 프로그래머스 Level 2. 코딩테스트 연습 - 숫자의 표현 | 프로그래머스 스쿨 (programmers.co.kr) 문제 Finn은 요즘 수학공부에 빠져 있습니다. 수학 공부를 하던 Finn은 자연수 n을 연속한 자연수들로 표현 하는 방법이 여러개라는 사실을 알게 되었습니다. 예를들어 15는 다음과 같이 4가지로 표현 할 수 있습니다. 1 + 2 + 3 + 4 + 5 = 15 4 + 5 + 6 = 15 7 + 8 = 15 15 = 15 자연수 n이 매개변수로 주어질 때, 연속된 자연수들로 n을 표현하는 방법의 수를 return하는 solution를 완성해주세요. 제한사항 • n은 10,000 이하의 자연수 입니다. 입출력 예 n result 15 4 문제 해결 방안 숫자 n..
[프로그래머스/Java] 이진 변환 반복하기 📚 이진 변환 반복하기 [JAVA] 프로그래머스 Level 2. 코딩테스트 연습 - 이진 변환 반복하기 | 프로그래머스 스쿨 (programmers.co.kr) 문제 0과 1로 이루어진 어떤 문자열 x에 대한 이진 변환을 다음과 같이 정의합니다. x의 모든 0을 제거합니다. x의 길이를 c라고 하면, x를 "c를 2진법으로 표현한 문자열"로 바꿉니다. 예를 들어, x = "0111010"이라면, x에 이진 변환을 가하면 x = "0111010" -> "1111" -> "100" 이 됩니다. 0과 1로 이루어진 문자열 s가 매개변수로 주어집니다. s가 "1"이 될 때까지 계속해서 s에 이진 변환을 가했을 때, 이진 변환의 횟수와 변환 과정에서 제거된 모든 0의 개수를 각각 배열에 담아 return 하도록 ..
Spring Boot JPA 영속성 컨텍스트 영속성 컨텍스트 엔티티를 영구적으로 저장하는 환경이라는 뜻이다. 애플리케이션과 데이터베이스 사이에서 객체를 보관하는 가상의 데이터베이스 역할을 한다. EntiyManagerFacotry & EntityManager JPA는 스레드가 하나 생성될 때 마다 EntitiymanagerFactory에서 EntityManager를 생성한다. 생성된 EntityManager는 내부적으로 DB 커넥션 풀을 사용해서 DB와 연결한다. Spring 에서 EntityManager를 주입받아서 쓰면 같은 트랙잭션 범위에 있는 EntityManager는 동일한 영속성 컨텍스트에 접근한다. 비영속(New / transient) 영속성 컨텍스트와 전혀 관계가 없는 상태 // 객체를 생성만 한 상태(비영속) Member membe..
[프로그래머스/Java] 올바른 괄호 📚 올바른 괄호 [JAVA] 프로그래머스 Level 2. 코딩테스트 연습 - 올바른 괄호 | 프로그래머스 스쿨 (programmers.co.kr) 문제 괄호가 바르게 짝지어졌다는 것은 '(' 문자로 열렸으면 반드시 짝지어서 ')' 문자로 닫혀야 한다는 뜻입니다. 예를 들어 "()()" 또는 "(())()" 는 올바른 괄호입니다. ")()(" 또는 "(()(" 는 올바르지 않은 괄호입니다. '(' 또는 ')' 로만 이루어진 문자열 s가 주어졌을 때, 문자열 s가 올바른 괄호이면 true를 return 하고, 올바르지 않은 괄호이면 false를 return 하는 solution 함수를 완성해 주세요. 제한사항 문자열 s의 길이 : 100,000 이하의 자연수 문자열 s는 '(' 또는 ')' 로만 이루어져 있..
[프로그래머스/Java] 문자열 만들기 📚 JadenCase 문자열 만들기 [JAVA] 프로그래머스 Level 2. 코딩테스트 연습 - JadenCase 문자열 만들기 | 프로그래머스 스쿨 (programmers.co.kr) 문제 JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고) 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요. 제한사항 s는 길이 1 이상 200 이하인 문자열입니다. s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다. 숫자는 단어의 첫 문자로만 나옵니다. 숫자로만 이루어진 단어는 없습니다. 공백문자가 ..