본문 바로가기

sql8

[프로그래머스] 자동차기록에서 장기/단기 대여 구분하기 | DATEDIFF, SQL IF문 개요 이 문제의 핵심은 대여 시작일이 2022년 9월이어야 한다. ➡️ date_format 함수로 DATE형 원하는 형식으로 수정하기 장기/단기 기간은 30일이 기준이다. ➡️ datediff 함수와 if문 이용하기 DATEDIFF 날짜의 차이를 일(day)로 환산해주는 함수. datediff(date1, date2) 계산은 date1 - date2로 진행된다. 음수는 0으로 도출된다. IF문 if문은 SELECT와 WHERE 절에 사용할 수 있다. IF문 if(조건, 참일 때 결과, 거짓일 때 결과) if(datediff(end_date,start_date) 2024. 2. 23.
[프로그래머스] 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기 | LIKE 사용법 개요 SQL의 LIKE문은 주로 쿼리문 WHERE와 함께 사용되며, 일치하는 컬럼을 찾을 때 사용한다. 해당 문제처럼, 컬럼에 다양한 정보가 있을 때 '통풍시트', '열선시트', '가죽시트' 등 특정 내용을 걸러내야 하는 경우에 사용하기 좋다. LIKE 사용법 -- A로 시작하는 문자 찾기 -- where 컬럼명 like 'A%' -- A로 끝나는 문자 찾기 -- where 컬럼명 like '%A' -- A를 포함하는 문자 찾기 -- where 컬럼명 like '%A%' -- A로 시작하는 두 글자의 문자 찾기 -- where 컬럼명 like 'A_' -- 첫 번째 문자가 'A'가 아닌 모든 문자열 찾기 -- where 컬럼명 like '[^A]' -- 첫 번째 문자가 'A' or 'B' or 'C'인 .. 2024. 2. 11.
[프로그래머스] 131530. 가격대 별 상품 개수 구하기 문제 PRODUCT 테이블에서 만원 단위의 가격대 별로 상품 개수를 출력하는 SQL 문을 작성해주세요. 이때 컬럼명은 각각 컬럼명은 PRICE_GROUP, PRODUCTS로 지정해주시고 가격대 정보는 각 구간의 최소금액(10,000원 이상 ~ 20,000 미만인 구간인 경우 10,000)으로 표시해주세요. 결과는 가격대를 기준으로 오름차순 정렬해주세요. group by기본 문제다. 문제를 잘 보면 만원 단위의 가격대 별로 상품 개수를 출력해야 한다. 상품 개수는 예시에 잘 나와있듯이 product_id를 집계 함수로 잘 세어주면 된다. 만원 단위의 가격대 별로 조작하기 위해서는, 현재 DB에 저장된 price 값을 조정하고, GROUP BY해야한다. SQL Integer 조작 14000, 23000 이런.. 2024. 2. 10.
[프로그래머스] 조건에 부합하는 중고거래 댓글 조회하기 문제 USED_GOODS_BOARD와 USED_GOODS_REPLY 테이블에서 2022년 10월에 작성된 게시글 제목, 게시글 ID, 댓글 ID, 댓글 작성자 ID, 댓글 내용, 댓글 작성일을 조회하는 SQL문을 작성해주세요. 결과는 댓글 작성일을 기준으로 오름차순 정렬해주시고, 댓글 작성일이 같다면 게시글 제목을 기준으로 오름차순 정렬해주세요. sql 문제를 풀 때는 원하는 결과값이 어떤 것인지?에 대해 먼저 파악해야 한다. 그리고 이 결과를 도출하기 위한 세부적인 연산에 대해 고민한다. 먼저, BOARD 테이블은 게시글에 대한 정보를 담고 있고, REPLY 테이블은 그 게시물의 첨부파일 정보를 담고 있다.(쉽게 생각해서 댓글이다. REPLY 테이블의 필드값을 통해 유추할 수 있다.) 이러한 정보를 보.. 2024. 2. 3.
[SQL] JOIN 개요 데이터베이스를 관리할 때는 데이터베이스 품질 보장을 위해 정규화(관계형 스키마를 세분화하는 것)를 한다. 이렇게 세분화된 테이블들은 연결되어 사용해야 하는 경우가 있다. 예를 들어, 학생 정보 테이블과 학과 정보 테이블이 정규화에 의해 분리되었고 학생의 학과 정보를 위해 두 테이블을 연결하여 정보를 얻는다. 이러한 연결을 위한 연산이 JOIN이다. JOIN 종류 카티션 곱(Cartesian Product): 모든 행에 대한 조인(합집합) 동등 조인(equi join): 공통 속성을 기준으로 같은 값을 가지는 행 조회(교집합) 비동등 조인(non-equi join): 공통 속성을 기준으로 >, =, 2024. 2. 3.
[프로그래머스] 조건에 맞는 도서 리스트 출력하기 | DATE DATE SQL의 DATE 타입은 YYYY-MM-DD hh:mm:ss 형식이다. select 문에서 DATE(datetype_record) 이렇게 사용하면 YYYY-MM-DD 부분만 추출한다. DATE_FORMAT으로 기본값인 YYYY-MM-DD hh:mm:ss를 변경할 수 있다. DATE Format 2024-02-01 18:31:45 날짜 및 요일 포맷 형식 결과값 %Y 2000 %y 00 %M February %b Feb %m 02 %d 01 %e 1 %a Thu 시간 포맷 형식 결과값 %H 18(24시간) %h 6(12시간) %i 31(분) %s / %S 45(초) %m 02 해당 문제는 시간을 제외하고 날짜를 'yyyy-mm-dd' 데이터를 출력해야 하므로, SQL문은 다음과 같다. date_f.. 2024. 2. 1.
[DB/MySQL] 기본 명령어2 | BEETWEEN, IN, LIKE, ALY, ALL BETWEEN 숫자로 구성된 연속적인 데이터 BETWEEN, AND SELECT * FROM city WHERE Population 7000000 AND 8000000 IN() 이산값 조건 SELECT * FROM city WHERE Name IN('Seoul', 'Pusan') LIKE 문자열의 내용 검색 (%랑 _ 사용) KOR 기억안남.. KO 뒤에 한 글자 머였더라..? 할 때 SELECT * FROM city WHERE CountryCode LIKE 'KO_' Tel로 시작하는 .. 도시 뭐더라..? 할 때 SELECT * FROM city WHERE Name LIKE 'tel %' ANY / SOME 서브 쿼리의 여러가지 조건 중 하나만 만족해도 출력 SELECT * FROM city WHER.. 2023. 2. 23.
[DB/MySQL] MySQL이란 SQL이란 DML(Data Manipulation Language), DDL(Data Definition Language), DCL(Data Control Language)로 나뉜다1. 1. DML (Manupulation : 다루기, 조작) 데이터를 조작하는 언어로, 주로 데이터 선택/삽입/수정/삭제하는 일을 한다. DML은 테이블의 행을 대상으로 작동하며 DML을 사용하기 위해서는 조작할 테이블이 정의되어 있어야 한다. ⭐️SQL 구문 중 SELECT, INSERT, UPDATE, DELETE.⭐️ 2. DDL (Definition : 정의) 데이터베이스, 테이블, 뷰, 인덱스 등의 db 개체를 생성/삭제/변경하는 일을 한다. ROCKBACK이나 COMMIT은 사용할 수 없다. 실행 즉시 MySQL에.. 2023. 2. 1.