분류 전체보기(204)
-
[내일배움캠프] TIL - 24.09.11(수)
어제부로 진행하던 '계산기 구현' 과제를 마무리하고 제출하였기에 오늘은 그 동안 과제 진행으로 'To Do List' 에 적어둔 것들을 학습하는 시간을 가졌다. 그간 코딩 문제(알고리즘 및 SQL)를 풀며 문제 해결에 도움이 되나 제대로 알고 있지 못핸 던 것들을 적어두었으며, 'To Do List' 에 적어둔 내용은 아래와 같다. 각 항목에 학습을 정리한 포스팅과 링크를 걸어 두었다.WITHUNIONIFNULLRECURSIVE개인적으로 학습간 'UNION' 에 대한 예시를 만들어 보면서 실무에서 크게 쓸 일이 있을까라는 의문이 들었는데, 해당 부분은 튜터님을 찾아가 실무 경험을 들어보며 어떠한 경우 해당 함수를 사용한 적이 있는지 들을 수 있었다. 단순 학습만으로는 예상하기 어려운 부분이었는데 직접 실..
2024.09.11 -
[SQL] 재귀를 활용한 반복문 - WITH RECURSIVE
Java 의 '반복문(for)' 과 비슷한 수행을 SQL 에서는 'Recursive CTE(Common Table Expressions)' 을 활용해 비슷하게 구현할 수 있다. 아무래도 한 번에 이해하기에는 어려워 Java 와 비교하며 이해하게 되었다. 1. 기본 문법WITH RECURSIVE 임시테이블명 AS ( SELECT 컬럼 첫 데이터 AS 컬럼별명 // 비재귀 SELECT 부분 UNION ALL SELECT 이전 컬럼값에 대한 연산 // 재귀 SELECT 부분 FROM 임시테이블명 WHERE 컬럼에 대한 조건식)SELECT 컬럼명FROM 임시테이블명 'WITH RECURSIVE' 는 'Recursive Common Table Expressions(재귀 공통 ..
2024.09.11 -
[SQL] NULL 변환 - IFNULL
간혹 선택지 외의 값을 가질 경우 컬럼 값을 null 로 지정하는 경우가 있다. 물론 null 값은 언제 터질 줄 모르는 시한폭탄 같기에 사용을 멀리해야 하지만 테이블 데이터를 가공하면서 null 값이 생기는 경우도 많다. 이럴 때 null 대신 다른 값을 지정하고 싶다면 'IFNULL' 함수를 사용하면 된다. 1. 기본 문법SELECT IFNULL(컬럼명, 지정값) AS 별명FROM 테이블명 사용 방법은 파라미터로 'null' 값을 변경할 타겟 컬럼의 이름과 해당 컬럼 값이 'null' 일 경우 변경(지정)할 값을 작성하면 된다. 이렇게 되면 컬럼 값이 'null' 인 경우 '지정값' 이 반환되고 'null' 이 아니라면 해당 컬럼 값이 반환된다. 2. 사용 예시 'test' 테이블의 'test_n..
2024.09.11 -
[SQL] 레코드 집합 합치기 - UNION
이전 학습한 'JOIN' 이 특정 컬럼을 기준으로 두 테이블의 레코드를 합치는 기능을 한다면, 'UNION' 은 같은 컬럼구성을 갖는 두 집합의 레코드를 합쳐 하나의 집합으로 만드는 기능을 한다. 1. 기본 문법SELECT column1, column2FROM table1UNION (or UNION ALL)SELECT column1, column2FROM table2 명확한 'UNION' 의 기능은 '두 개이상의 SELECT 문의 결과 집합을 결합' 하는 것이라 한다. 당연하게도 결합할 집합은 같은 개수의 컬럼을 가져야하고 컬럼구성(컬럼명, 컬럼타입)이 같아야 한다. 위의 문법을 통해 좀 더 설명하면 아래의 조건을 만족해야 하는 것이다.'table1.column1' 과 'table2.column1' 의..
2024.09.11 -
[SQL] 임시 테이블 생성 - WITH
기존에 원하는 결과 테이블을 얻기 위해 'SUBQUERY(하위 쿼리)' 를 자주 사용하였는데, 하위 쿼리를 여러 개 사용하다보면 쿼리 작성이 복잡해지는 경우를 겪었고 이 문제를 해결하기 위해 'WITH' 을 사용하게 되었다. WITH 은 'Commont Table Expressions(CTE, 공통 테이블 표현식)' 이라고도 말하는 함수이다. 'CTE' 는 단일 문의 범위 내에 존재하며, 해당 단일 문 안에서 여러 번 참조 가능한 '임시 결과 집합(임시 테이블, 가상 테이블)' 이라 한다. 1. 기본 문법// 임시 테이블(= 가상 테이블)WITH 임시테이블명1 AS ( SELECT 컬럼명... FROM 테이블명), 임시테이블명2 AS ( SELECT 컬럼명... FROM 테이블명)/..
2024.09.11 -
[내일배움캠프] TIL - 24.09.10(화)
이전 TIL 에 작성한대로 과제의 요구사항에는 없지만 필요하고, 반영하고 싶었던 부분을 반영해 'Level04 계산기' 를 개인적으로 구현해 보았다. 반영한 부분은 'Exception 활용' 과 '메서드의 기능 최소화' 이다. 사실 반영하고자 하면 이전 계산기에 충분히 반영할 수 있는 부분이었지만 애초에 프로젝트를 요구사항을 반영하면서 어떻게 구현이 달라지는지 확인하고자 레벨별 계산기를 분리하였기에 요구사항에 대한 부분을 우선적으로 구현하고, 이제야 추가 계산기를 구현해 반영하게 되었다. 예상대로 마지막 구현했던 'Level03 계산기' 와는 차이점을 쉽게 파악할 수 있었고 해당 차이점을 통해 'Exception' 을 활용하면 어떤 이점이 있는지를 알 수 있는 경험을 하게 되었다. 'Level04 계산기..
2024.09.10