일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- dsf
- airflow webserver
- 백준온라인저지
- leetcode
- BOT
- 백준 온라인 저지
- Spark
- Data Engineering
- SQL
- data_engineer
- hackerrank
- datacamp
- Pseudo Lab
- Dynamic Programming
- docker container
- 프로그래머스
- Airflow
- docker
- 데이터 엔지니어
- 알고리즘
- 빅데이터를 지탱하는 기술
- 그리디
- MySQL
- telegram
- terraform
- delete join
- airflow architecture
- Python
- 2023년 목표
- docker image
Archives
- Today
- Total
Lim Seunghyun Space
[Leetcode] Exchange Seats 본문
Source
Exchange Seats - LeetCode
Can you solve this real interview question? Exchange Seats - Table: Seat +-------------+---------+ | Column Name | Type | +-------------+---------+ | id | int | | student | varchar | +-------------+---------+ id is the primary key column for this table. Ea
leetcode.com
문제
- 연속된 두 학생의 ID를 교환하는 쿼리를 작성
- 마지막 학생의 ID가 홀수인 경우, ID를 교환하지 않음
- 출력한 칼럼은 id, student
- 쿼리 결과는 ID의 오름차순으로 정렬
Solution (MySQL)
SELECT
CASE
WHEN id % 2 = 1 AND id = (SELECT MAX(id) FROM Seat) THEN id
WHEN id % 2 = 0 THEN id - 1
WHEN id % 2 = 1 THEN id + 1
END AS id,
student
FROM Seat
ORDER BY id;
728x90
'SQL > SQL 문제' 카테고리의 다른 글
[LeetCode] Capital Gain/Loss (0) | 2023.03.30 |
---|---|
[LeetCode] Market Analysis I (0) | 2023.03.18 |
[Leetcode] 197. Rising Temperature (0) | 2022.04.18 |
[Leetcode] 196. Delete Duplicate Emails (0) | 2022.04.18 |
[Leetcode] 184. Department Highest Salary (0) | 2022.03.25 |