코틀린을 공부하면서 자바와 의존성 주입 차이가 약간 다른 거 같아서, 이번 글을 통해 제대로 정리하고자 합니다.코틀린이 자바보다 간결하게 처리가 가능하다고 말로만 들었는데, 의존성 주입부터 간결해지는 거 같다..의존성 주입 방법은 제일 많이 사용하는 생성자 주입을 기준으로만 작성하겠습니다. (가장 흔히 쓰고, 안전한 방식)Java 생성자 주입@RestController@RequiredArgsConstructorpublic class HelloController { private final HelloService helloService;}자바에서는 @RequiredArgsConstructor와 private final 빈 클래스 선언을 통해 간단하게 생성자 주입을 처리합니다. @RestControll..
문제 위 문제는 탈출할 수 있는 최단 거리를 구하는 문제인데, 2차원 배열이 아닌 3차원 배열을 통해 BFS 탐색을 진행해야 한다.여러 개의 테스트 케이스를 받아 최단 거리를 출력해야 하므로, 무한 루프와 break 조건을 적절하게 설정해줘야 한다.코드from collections import dequeimport sysinput = sys.stdin.readline# 남북서동 상하dx = [-1, 1, 0, 0, 0, 0]dy = [0, 0, -1, 1, 0, 0]dz = [0, 0, 0, 0, -1, 1]while True: L, R, C = map(int, input().split()) if L == 0 and R == 0 and C == 0: break start = None b..
복합 인덱스 알아보기복합 인덱스는 단어 그대로 여러 개의 컬럼 조합으로 생성된 인덱스이다.(idx_col1, idx_col2) 에 대해 인덱스를 설정하면, 명시한 컬럼 순서대로 인덱스가 정렬됩니다.B+ Tree 구조를 만들 때 idx_col1 컬럼에 대해 먼저 정렬을 하고, 동일한 값이 있다면 idx_col2를 기준으로 정렬하여 인덱스를 관리합니다.복합 인덱스 구조를 보면 첫 번째 컬럼을 먼저 조회하고 그다음에 두 번째 컬럼을 조회하는 것을 알 수 있습니다. 그래서 해당 인덱스를 제대로 사용하기 위해서는 순서에 맞게 Query를 구성해야 합니다.만약, idx_col2를 먼저 탐색하고 idx_col1을 탐색하게 where 조건문을 설정했다면, 올바르게 인덱스 탐색이 이루어지지 않을 수 있습니다. CREAT..
머리말,실무를 진행하면서 개발했던 서비스에 추가 요구사항이 생겨 테이블 변경이 필요한 상황이었습니다.1:1 관계였던 테이블이 N:M 관계로 변해 반정규화나 매핑 테이블을 추가해서 요구사항에 맞게 재설계 과정이 필요했습니다. Why 일대일 관계가 다대다 관계가 됐는지,더보기기존 서비스에서는 특정 시간 대에 하나의 객실에 대해 문의 예약건을 받아 처리했습니다. (문의 하나당 객실 하나를 담당한다.)하지만, 해당 기능은 사용자뿐만 아니라 관리자(사내 임직원)들도 사용하는 기능이어서 문의 하나 당 하나의 객실을 담당하게 되면 문의를 등록하는 데 불편한 점이 있었습니다. 그래서 이를 하나의 문의에 여러 개의 객실을 관리할 수 있도록 ERD를 재설계하였습니다.* 1:N 관계로 하게 되는 경우 객실 정보를 제외한 나..