전체 글 64

SQL) 재귀 CTE

프로그래머스 SQL 고득점 kit를 풀던 중 재귀 CTE를 사용하는 문제가 있어 공부한 내용을 정리해보고자 한다. https://school.programmers.co.kr/learn/courses/30/lessons/301651  프로그래머스SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프programmers.co.kr CTE란?WITH 키워드로 선언하는 나타내는 재사용 가능한 서브쿼리로 프로그래밍 언어로 따지면 일종의 메서드로 볼 수 있다.CTE는 FROM절, JOIN 절, WHERE 절 등 다양한 위치에서 쿼리의 일부처럼 사용할 수 있다.또한 쿼리 내에서 여러번 참조할 수 있어 중복을 피하는데 유용하다. CTE의 기본 구문WITH CTE_n..

DB/SQL 2025.03.05

우아한테크코스 7기 프리코스 최종 회고

안녕하세요! 오늘 프리코스 결과가 나온김에 작성하는 최종 회고입니다결과는 아쉽게도 탈락이었지만 여태까지의 과정을 정리해보면서 탈락의 원인이 무엇이었는지 스스로나마 찾아보고 반성해보고자 합니다.자소서우테코 지원 자기소개서에서는 크게 지원동기, 몰입 경험, 프리코스 목표 이 세가지를 질문했는데 이 중에서 몰입 경험과 프리코스 목표 부분이 개인적으로 아쉽게 느껴졌습니다.저는 몰입 경험 문항이 우테코에서 얼마나 몰입할 수 있겠는가를 묻는 문항이라고 생각했고, 프리코스에 참여하기 이전에 부트캠프를 수료한 경험이 있어 이 경험을 설명하면 충분한 몰입 경험 대답이 되겠다 싶어서 작성했습니다.하지만 저는 경험들을 나열했을 뿐 어떤 기술에 대해서 파고들어봤다, 어떤 것까지 구현해봤다 같은 '몰입'에 대해서는 작성하지 못..

도커 컨테이너 다루기

도커 컨테이너의 생애주기도커 컨테이너는 실행 중, 정지, 파기 3가지 상태를 갖는다. 실행 중 상태docker container run 명령으로 Dockerfile에 포함된 인스트럭션에 정의된 애플리케이션(컨테이너)을 최초 실행한 시점의 상태는 실행 중이다.실행이 끝나면 정지 상태가 된다. 정지 상태컨테이너를 정지시키면 디스크에 종료 시점의 상태가 저장돼 남는다.그러므로 정지시킨 컨테이너를 다시 실행할 수 있다. 파기 상태정지 상태의 컨테이너는 파기하지 않는 이상 디스크에 그대로 남아있다.컨테이너를 자주 생성하고 정지해야 한다면 디스크를 차지하는 용량이 늘어나므로 불필요한 컨테이너를 파기하는 것이 좋다.다만 한 번 파기한 컨테이너는 다시 실행할 수 없다. docker container run - 컨테이너..

Infra/Docker 2024.12.07

도커 이미지 다루기

도커 명령은 크게 이미지에 대한 명령과 컨테이너에 대한 명령 두가지로 나뉜다. 도커 이미지 다루기도커 이미지는 빌드할 때마다 다시 생성되는데, 내용의 해시값을 이미지 ID로 삼기 때문에 내용이 바뀌면 이미지 ID도 새 값이 부여된다. 도움말옵션에 대한 도움말docker help이미지 하위 옵션에 대한 도움말docker image --help docker image build - 이미지 빌드docker image build는 Dockerfile에 기술된 구성을 따라 도커 이미지를 생성하는 명령이다.docker image build -t 이미지명[:태그명] Dockerfile의_경로-t 옵션은 이미지명과 태그명을 붙이는 것으로 필수적으로 사용된다. 예를 들어 Dockerfile이 현재 작업 디렉터리에 있다면..

Infra/Docker 2024.12.07

컨테이너로 애플리케이션 실행하기

컨테이너로 애플리케이션 실행하기image 받아오기docker image pull 이미지명[:태그명] // ex) docker image pull gihyodocker/echo:latest컨테이너 실행컨테이너 실행을 하려면 docker에 이미지가 존재해야한다.예시는 -p [호스트포트:컨테이너포트]를 통해 포트포워딩을 수행한다.docker container run [옵션] 이미지명 [:태그명] // ex) docker container run -t -p 9000:8080 gihyodocker/echo:latest -d 옵션을 붙여 백그라운드로 컨테이너를 실행할 수도 있다.네트워크 주소 접근curl http://localhost:9000/컨테이너 정지docker stop 컨테이너명컨테이너 삭제컨테이너를 삭제하..

Infra/Docker 2024.12.06

모던 자바 인 액션 - chapter 7, 8 병렬 데이터 처리와 성능, 컬렉션 API 개선

병렬 데이터 처리와 성능자바 7은 쉽게 병렬화를 수행하면서 에러를 최소화할 수 있도록 fork/join 프레임워크 기능을 제공한다.병렬 스트림컬렉션에 parallelStream을 호출하면 병렬 스트림이 생성된다. 병렬 스트림은 각각의 스레드에서 처리할 수 있도록 스트림 요소를 여러 청크로 분할한 스트림이다. 따라서 병렬 스트림을 이용하면 모든 멀티코어 프로세서가 각각의 청크를 처리하도록 할당할 수 있다.stream에서 parallel을 호출하면 내부적으로 이후 연산이 병렬로 수행한다. 반대로 sequential로 병렬 스트림을 순차 스트림으로 바꿀 수 있다. 이 두 메서드를 이용해서 병렬로 실행할지 순차로 실행할지 제어할 수 있다. 이 중 최종적으로 호출된 메서드가 전체 파이프라인에 영향을 미친다.병렬 ..

Java 2024.11.30

모던 자바 인 액션 - chapter 6 스트림 데이터 수집

스트림으로 데이터 수집컬렉터Collector 인터페이스는 어떻게 구현하느냐에 따라 스트림에 어떤 리듀싱 연산을 수행할지 결정된다. Collectors 유틸리티 클래스는 자주 사용하는 컬렉터 인스턴스를 손쉽게 생성할 수 있는 정적 팩토리 메서드를 제공한다.Collectors에서 제공하는 메서드의 기능은 크게 세가지로 구분할 수 있다.스트림 요소를 하나의 값으로 리듀스하고 요약요소 그룹화요소 분할리듀싱과 요약counting: 개수를 카운트한다maxBy, minBy: 최대 혹은 최소를 만족하는 요소를 찾는다summingInt: 객체를 int로 매핑하는 인수를 받아 합 계산averagingInt: 객체를 int로 매핑하는 인수를 받아 평균을 계산한다summarizingInt: 요소 수, 합계, 평균, 최대값, ..

Java 2024.11.29

모던 자바 인 액션 - chapter 4, 5 스트림과 활용

스트림 스트림이란 무엇인가?선언형으로 컬렉션 데이터를 처리할 수 있도록 자바 8 API에 추가된 기능이다. 또한 멀티스레드 코드를 구현하지 않아도 손쉽게 데이터를 병렬 처리할 수 있다.스트림의 장점은 다음과 같다.선언형으로 코드를 구현할 수 있다.여러 블록연산을 연결해서 복잡한 데이터 처리 파이프라인을 만들 수 있다.병렬 스트림을 사용하여 데이터 처리 속도를 높일 수 있다.원본 데이터를 변경하지 않으므로 데이터의 불변성을 유지할 수 있다.지연 연산을 통해 필요할 때만 연산을 수행하여 성능을 최적화할 수 있다.** 지연 연산: filter, map과 같은 중간 연산은 collect와 같은 최종 연산이 호출되었을 때만 실행된다.컬렉션과 스트림컬렉션은 현재 자료구조가 포함하는 모든 값을 메모리에 저장하는 자료..

Java 2024.11.20

모던 자바 인 액션 - chapter 2, 3 동작 파라미터화, 람다 표현식

동작 파라미터화동작 파라미터화는 메서드 내부적으로 다양한 동작을 수행할 수 있도록 코드를 메서드 인수로 전달한다. 이는 자주 바뀌는 요구사항에 효과적으로 대응할 수 있다. 동작 파라미터화 방법기존엔 클래스를 통한 동작을 메서드의 인수로 전달하는 방법을 통해 구현해야 했다. 익명 클래스로도 어느 정도 코드를 깔끔하게 만들 수 있지만 자바 8에서는 인터페이스를 상속받아 여러 클래스를 구현해야 하는 수고를 없앨 수 있는 람다(익명 함수)를 제공한다.선택 조건을 결정하는 인터페이스 선언(Predicate)public interface ApplePredicate { boolean test(Apple apple);}클래스를 통한 동작 파라미터화public class AppleGreenColorPredicate..

Java 2024.11.19

모던 자바 인 액션 - chapter 1 자바 8 무슨 일이 일어나고 있는가

프로그래밍 분야는 빅데이터라는 도전에 직면하면서 멀티코어 컴퓨터나 컴퓨팅 클러스터를 이용해서 빅데이터를 효과적으로 처리할 필요성이 증가했다. 또한 병렬 프로세싱을 활용해야 하는데 이전의 자바로는 충분히 대응할 수 없었다. 자바 8부터 추가되는 기능은 현 시장에 요구하는 기능을 효과적으로 제공한다. 이 책은 자바 8에서 제공하는 기능의 모태인 세 가지 프로그래밍 개념을 상세히 설명한다.세 가지 프로그래밍 개념스트림 처리스트림 API는 파이프라인(중간 연산이 연결되어 하나의 연산을 이루는 것)을 만드는데 필요한 많은 메서드를 제공한다. 또한 Thread를 사용하지 않으면서 병렬성을 손쉽게 얻을 수 있다.동작 파라미터화로 메서드에 코드 정달하기메서드를 파라미터화 해서 전달가능하다. 함수형 프로그래밍 기술을 활..

Java 2024.11.19