❓ Question https://www.hackerrank.com/challenges/select-all-sql Select All | HackerRank Query all columns for every row in a table. www.hackerrank.com ❗ Answer SELECT * FROM city; 📌 Discussion - SELECT 절에서 *로 모든 레코드를 추출
❓ Question https://www.hackerrank.com/challenges/revising-the-select-query-2 Revising the Select Query II | HackerRank Query the city names for all American cities with populations larger than 120,000. www.hackerrank.com ❗ Answer SELECT name FROM city WHERE countrycode = 'USA' AND population > 120000; 📌 Discussion WHERE 절에서 조건을 걸어주고 SELECT 절에서 필요 컬럼만 추출
❓ Question https://www.hackerrank.com/challenges/revising-the-select-query Revising the Select Query I | HackerRank Query the data for all American cities with populations larger than 100,000. www.hackerrank.com ❗ Answer SELECT * FROM city WHERE countrycode = 'USA' AND population > 100000; 📌 Discussion WHERE 절에서 조건문으로 필터링
❓ Question ❗ Answer SELECT YEAR(sale.sales_date) year , MONTH(sale.sales_date) month , COUNT(DISTINCT sale.user_id) purchased_users , ROUND(COUNT(DISTINCT sale.user_id)/(SELECT COUNT(*) FROM user_info WHERE YEAR(joined) = '2021'),1) purchased_ratio FROM user_info info INNER JOIN online_sale sale ON info.user_id = sale.user_id WHERE YEAR(info.joined) = '2021' GROUP BY year, month ORDER BY year, m..
❓ Question ❗ Answer SELECT d.history_id, ROUND(d.duration*d.daily_fee*(100-IFNULL(p.discount_rate,0))/100) fee FROM (SELECT r.history_id, r.car_id, r.daily_fee, r.duration, r.car_type, (CASE WHEN r.duration < 7 THEN NULL WHEN r.duration BETWEEN 7 AND 29 THEN '7일 이상' WHEN r.duration BETWEEN 30 AND 89 THEN '30일 이상' ELSE '90일 이상' END) duration_type FROM (SELECT h.history_id, c.car_id, c.car_type, c..
❓ Question ❗ Answer SELECT b.title, b.board_id, r.reply_id, r.writer_id, r.contents, DATE_FORMAT(r.created_date,'%Y-%m-%d') FROM used_goods_board b INNER JOIN used_goods_reply r ON b.board_id = r.board_id WHERE b.created_date LIKE '2022-10%' ORDER BY r.created_date, b.title; 📌 Discussion created_date라는 column이 양쪽에 모두 있으나 다른 값인 것을 유의하여 조건절에 사용해야한다.
❓ Question ❗ Answer # set 함수 이용 SET @HOUR := -1; # 초기 변수 설정, 세미콜론으로 종료 해줘야함 SELECT (@HOUR := @HOUR+1) HOUR, # HOUR 변수에 +1 반복 (SELECT COUNT(*) FROM animal_outs WHERE HOUR(datetime) = @HOUR) COUNT FROM animal_outs WHERE @HOUR < 23 # 마지막으로 +1한 HOUR가 23이면 반복 멈춤 ORDER BY HOUR; 📌 Discussion SET으로 변수를 설정해주고 @로 반복문을 실행해줌 WHERE 문에서 반복문 중지 조건을 넣어줌