hdonghun / SQL

1 stars 0 forks source link

SQL 문제 풀기_ HACKER RANK - New Companies #35

Open hdonghun opened 2 years ago

hdonghun commented 2 years ago

HACKER RANK - New Companies 출처 : https://www.hackerrank.com/challenges/the-company/problem

Amber's conglomerate corporation just acquired some new companies. Each of the companies follows this hierarchy: image

Given the table schemas below, write a query to print the company_code, founder name, total number of lead managers, total number of senior managers, total number of managers, and total number of employees. Order your output by ascending company_code.

Sample Input Company Table: image

Lead_Manager Table: image

Senior_Manager Table:
image

Manager Table:
image

Employee Table: image

Sample Output C1 Monika 1 2 1 2 C2 Samantha 1 1 2 2 Explanation

In company C1, the only lead manager is LM1. There are two senior managers, SM1 and SM2, under LM1. There is one manager, M1, under senior manager SM1. There are two employees, E1 and E2, under manager M1.

In company C2, the only lead manager is LM2. There is one senior manager, SM3, under LM2. There are two managers, M2 and M3, under senior manager SM3. There is one employee, E3, under manager M2, and another employee, E4, under manager, M3.

hdonghun commented 2 years ago

MYSQL : SELECT C.COMPANY_CODE, C.FOUNDER, (SELECT COUNT(DISTINCT LEAD_MANAGER_CODE) FROM LEAD_MANAGER WHERE COMPANY_CODE = C.COMPANY_CODE), (SELECT COUNT(DISTINCT SENIOR_MANAGER_CODE) FROM SENIOR_MANAGER WHERE COMPANY_CODE = C.COMPANY_CODE), (SELECT COUNT(DISTINCT MANAGER_CODE) FROM MANAGER WHERE COMPANY_CODE = C.COMPANY_CODE), (SELECT COUNT(DISTINCT EMPLOYEE_CODE) FROM EMPLOYEE WHERE COMPANY_CODE = C.COMPANY_CODE) FROM COMPANY C ORDER BY COMPANY_CODE

hdonghun commented 2 years ago

MSSQL : SELECT C.COMPANY_CODE, C.FOUNDER, (SELECT COUNT(DISTINCT LEAD_MANAGER_CODE) FROM LEAD_MANAGER WHERE COMPANY_CODE = C.COMPANY_CODE), (SELECT COUNT(DISTINCT SENIOR_MANAGER_CODE) FROM SENIOR_MANAGER WHERE COMPANY_CODE = C.COMPANY_CODE), (SELECT COUNT(DISTINCT MANAGER_CODE) FROM MANAGER WHERE COMPANY_CODE = C.COMPANY_CODE), (SELECT COUNT(DISTINCT EMPLOYEE_CODE) FROM EMPLOYEE WHERE COMPANY_CODE = C.COMPANY_CODE) FROM COMPANY C ORDER BY COMPANY_CODE ASC