+-------------+----------+
| Column Name | Type |
+-------------+----------+
| account_id | int |
| ip_address | int |
| login | datetime |
| logout | datetime |
+-------------+----------+
This table may contain duplicate rows.
The table contains information about the login and logout dates of Leetflex accounts. It also contains the IP address from which the account was logged in and out.
It is guaranteed that the logout time is after the login time.
Write a solution to find the account_id of the accounts that should be banned from Leetflex. An account should be banned if it was logged in at some moment from two different IP addresses.
Input:
LogInfo table:+------------+------------+---------------------+---------------------+| account_id | ip_address | login | logout |+------------+------------+---------------------+---------------------+|1|1|2021-02-0109:00:00|2021-02-0109:30:00||1|2|2021-02-0108:00:00|2021-02-0111:30:00||2|6|2021-02-0120:30:00|2021-02-0122:00:00||2|7|2021-02-0220:30:00|2021-02-0222:00:00||3|9|2021-02-0116:00:00|2021-02-0116:59:59||3|13|2021-02-0117:00:00|2021-02-0117:59:59||4|10|2021-02-0116:00:00|2021-02-0117:00:00||4|11|2021-02-0117:00:00|2021-02-0117:59:59|+------------+------------+---------------------+---------------------+Output:
+------------+| account_id |+------------+|1||4|+------------+Explanation:
Account ID 1--> The account was active from "2021-02-01 09:00:00" to "2021-02-01 09:30:00"with two different IP addresses(1 and 2). It should be banned.Account ID 2--> The account was active from two different addresses(6,7) but in**two different times**.Account ID 3--> The account was active from two different addresses(9,13) on the same day but **they do not intersect at any moment**.Account ID 4--> The account was active from "2021-02-01 17:00:00" to "2021-02-01 17:00:00"with two different IP addresses(10 and 11). It should be banned.
If two different accounts log in from the same IP address with overlapping login/logout times, both accounts should be banned. We need to find all such pairs and collect all unique account IDs involved.
SELECTDISTINCT a.account_id AS banned_account
FROM LogInfo a
JOIN LogInfo b
ON a.ip_address = b.ip_address
AND a.account_id <> b.account_id
AND a.login < b.logout
AND b.login < a.logout
ORDERBY banned_account;
1
2
3
4
5
6
7
8
SELECTDISTINCT a.account_id AS banned_account
FROM LogInfo a
JOIN LogInfo b
ON a.ip_address = b.ip_address
AND a.account_id <> b.account_id
AND a.login < b.logout
AND b.login < a.logout
ORDERBY banned_account;