MySQL 41

[프로그래머스] 없어진 기록 찾기

SELECT ANIMAL_ID, NAME FROM ANIMAL_OUTS where ANIMAL_ID not in (select ANIMAL_ID from ANIMAL_INS); 위 코드는 내 생각대로 작성한 코드이다. ANIMAL_OUTS 테이블에는 값이 있고 ANIMAL_IN 테이블에는 값이 없어야 하므로 차집합을 생각했다. 검색해보니, mysql에는 차집합 연산이 없어 서브쿼리로 진행해야 한다고 한다. 위 코드는, ANIMAL_OUTS의 ANIMAL_ID 중 ANIMAL_INS의 ANIMAL_ID와 겹치지 않는 (없는) 값들을 조회하도록 했다. [실행결과] 다음은, 구글링 후 JOIN 연산자를 사용하여 문제를 해결한 코드다. INNER JOIN과 LEFT OUTER JOIN이 많이 쓰인다고 한다. S..

Language/SQL 2022.07.05

[프로그래머스] 입양 시각 구하기(2)

SELECT hour(DATETIME) HOUR, count(DATETIME) COUNT FROM ANIMAL_OUTS GROUP BY HOUR ORDER BY HOUR; 위 코드는 잘못된 코드이다. 문제는 0~23시까지 모든 시가 출력되길 원하기 때문이다. SET 명령어를 사용해야 한다. SET 명령어는 변수에 특정한 값을 넣어줄 때 사용한다. @은 변수명 앞에 써주어야 한다. (ex. @HOUR) :=는 대입 연산자로, SET명령어에서는 =, := 둘다 대입 연산자로 인식된다. SET을 제외한 다른 쿼리문(ex. SELECT)은 '='를 비교연산자로 인식한다. SET @HOUR = -1; SELECT (@HOUR := @HOUR + 1) HOUR, (SELECT count(DATETIME) COUNT..

Language/SQL 2022.07.04