Language/SQL(27)
-
[SQL] 이후 날짜 구하기 - DATE_ADD, ADDDATE
날짜 데이터에 특정 값을 더해 이후 날짜 데이터를 반환하는 'DATE_ADD, ADDDATE' 에 대해 알아보자. 1. 기본 문법SELECT DATE_ADD(기준 날짜 데이터, INTERVAL 간격 값 및 유형) AS 별명FROM 테이블명 DATE_ADD (= ADDDATE) 특정 날짜 데이터에 지정한 유형의 간격 값을 더하는 함수'ADDDATE' 와 'DATE_ADD' 함수는 서로 같은 함수이다. 개인적으로 생각하기에는 'ADDDATE' 라는 명칭이 식별하기 불편해 'DATE_ADD' 로 이름만 바꾼 함수를 추가한 것으로 보인다. 그래서 'ADDDATE' 함수를 사용하는 경우 함수명만 바꿔 사용하면 된다.'유형' 은 더할 데이터가 '년(year)' 인지 '월(month)' 인지 등을 구별하기 위한 유형..
2024.09.24 -
[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 -
[SQL] 그룹별 데이터 합치기 - GROUP_CONCAT
데이터를 한 문자열로 합칠 때 CONCAT 을 사용해 만들 수 있었다. 이번에는 그룹별 컬럼이 가지고 있는 데이터를 하나로 합치는 GROUP_CONCAT 에 대해서 알아보자. 1. 기본 문법SELECT 그룹할 컬럼명, GROUP_CONCAT(지정컬럼명 SEPARATOR 구분자) 별명FROM 테이블명GROUP BY 그룹할 컬럼명 일단 해당 함수를 사용하려면 GROUP BY 절을 사용해 데이터를 그룹화 해야한다. 그렇기에 기본 문법에 GROUP BY 절을 추가해 두었다. 기능은 기존 CONCAT 과 같지만 GROUP_CONCAT 은 집계 함수라는 점이 다르다. 그룹화 된 컬럼의 데이터들을 합쳐 한 문자열 데이터(LONGTEXT)로 출력하는 기능을 가지고 있다. SEPARATOR 의 경우 원하는 구분자가 ..
2024.08.30