zoukankan      html  css  js  c++  java
  • LeetCode

    Mary is a teacher in a middle school and she has a table seat storing students' names and their corresponding seat ids.

    The column id is continuous increment.

    Mary wants to change seats for the adjacent students.

    Can you write a SQL query to output the result for Mary?

    +---------+---------+
    |    id   | student |
    +---------+---------+
    |    1    | Abbot   |
    |    2    | Doris   |
    |    3    | Emerson |
    |    4    | Green   |
    |    5    | Jeames  |
    +---------+---------+
    

    For the sample input, the output is:

    +---------+---------+
    |    id   | student |
    +---------+---------+
    |    1    | Doris   |
    |    2    | Abbot   |
    |    3    | Green   |
    |    4    | Emerson |
    |    5    | Jeames  |
    +---------+---------+
    

    Note:
    If the number of students is odd, there is no need to change the last one's seat.

    # Write your MySQL query statement below
    SELECT
        s.id,
        s.student
    FROM
        (
            SELECT
                id - 1 AS id,
                student
            FROM
                seat
            WHERE
                (id % 2 = 0)
            UNION
                SELECT
                    (CASE WHEN (cnt%2=1) AND id=cnt THEN id ELSE id + 1 END) AS id,
                    student
                FROM
                    seat,
                    (select count(*) as cnt from seat) as seatcnt
                WHERE
                    (id % 2 = 1)
        ) s
    GROUP BY
        s.id ASC
  • 相关阅读:
    重建Exchange邮件系统的系统邮箱
    枚举算法001
    关于网站备案的44个问题
    wireshack使用
    格言
    程序员遇到BUG的解释
    只要有信心任何事情都可以做成,今天表现不错哦,加油!
    踏实,自信
    学会经营自己的关系
    戒酒
  • 原文地址:https://www.cnblogs.com/wxisme/p/7520231.html
Copyright © 2011-2022 走看看