문제 - Customer Who Visited but Did Not Make Any Transactions
https://leetcode.com/problems/customer-who-visited-but-did-not-make-any-transactions/
Write a SQL query to find the IDs of the users who visited without making any transactions and the number of times they made these types of visits.
Return the result table sorted in any order.
작성 답안
select v.customer_id, count(*) as count_no_trans
from visits v left join transactions t
on v.visit_id = t.visit_id
where t.transaction_id is null
group by v.customer_id
리뷰
discussion을 보니 join을 사용하지 않고 푸는 방법이 있어 가져와보았다.
SELECT customer_id, COUNT(visit_id) as count_no_trans
FROM Visits v
WHERE NOT EXISTS (
SELECT visit_id FROM Transactions t
WHERE t.visit_id = v.visit_id
)
GROUP BY customer_id
# https://leetcode.com/problems/customer-who-visited-but-did-not-make-any-transactions/discuss/2533481/3-Different-solutions-(JOIN-NOT-IN-NOT-EXISTS)
EXISTS([subquery])
subquery의 결과가 존재하는지 여부를 확인하기 위해 사용된다.
주요 쿼리의 각 행에 대해 조건을 평가하는데 사용하며, 주요 쿼리 결과는 서브쿼리 조건을 만족하는 행만 포함하게 된다.
해당 문제에서는 transaction 테이블에 Visit 테이블의 visit_id가 없는 행을 뽑아야 하기 때문에, NOT EXISTS를 통해 구현할 수 있다.
'SQL' 카테고리의 다른 글
[leetCode] #1661 (1) | 2023.08.07 |
---|---|
[leetCode] #197 (날짜 차이 계산하기/TO_DAYS, DATEDIFF, SUBDATE) (0) | 2023.08.06 |
[leetCode] # 1378 (0) | 2023.08.01 |
[leetCode] #1683 (length와 char_length의 차이) (0) | 2023.07.31 |
[leetCode] #1148 (쿼리실행순서) (0) | 2023.07.19 |