|
3 | 3 | <img src="./art/57.png" alt="solution" >
|
4 | 4 |
|
5 | 5 | #### eng:
|
| 6 | +You are given a table, Projects, containing three columns: Task_ID, Start_Date and End_Date. It is guaranteed that the difference between the End_Date and the Start_Date is equal to 1 day for each row in the table. |
6 | 7 |
|
7 | 8 |
|
8 | 9 |
|
| 10 | +If the End_Date of the tasks are consecutive, then they are part of the same project. Samantha is interested in finding the total number of different projects completed. |
| 11 | + |
| 12 | +Write a query to output the start and end dates of projects listed by the number of days it took to complete the |
| 13 | +project in ascending order. If there is more than one project that have the same number of completion days, then |
| 14 | +order by the start date of the project. |
| 15 | + |
| 16 | + |
9 | 17 | #### рус:
|
| 18 | +Вам дана таблица Projects, содержащая три столбца: Task_ID, Start_Date и End_Date. Гарантируется, что разница между End_Date и Start_Date равна 1 дню для каждой строки в таблице. |
| 19 | + |
10 | 20 |
|
11 | 21 |
|
| 22 | +Если End_Date задач совпадают, то они являются частью одного и того же проекта. Саманте интересно узнать общее количество завершенных различных проектов. |
| 23 | + |
| 24 | +Напишите запрос для вывода дат начала и окончания проектов, перечисленных по количеству дней, затраченных на |
| 25 | +выполнение проекта, в порядке возрастания. Если имеется более одного проекта с одинаковым количеством дней |
| 26 | +завершения, заказывайте по дате начала проекта. |
| 27 | + |
12 | 28 |
|
13 | 29 | #### код с коментариями:
|
14 | 30 | ```sql
|
15 |
| - |
| 31 | +/* Этот внешний запрос предназначен только для упорядочения по продолжительности проекта */ |
| 32 | +SELECT |
| 33 | + P3.sd,P3.ed |
| 34 | +FROM |
| 35 | + (SELECT |
| 36 | + MIN(P1.Start_Date) AS sd, |
| 37 | + P2.End_Date AS ed |
| 38 | + FROM Projects AS P1 |
| 39 | + INNER JOIN Projects AS P2 |
| 40 | + ON p2.End_Date |
| 41 | + NOT IN (SELECT |
| 42 | + Start_Date |
| 43 | + FROM Projects) |
| 44 | + /*мы исключаем даты окончания, существующие на Start_Date, что означает, что они являются частью одного и того же проекта*/ |
| 45 | + AND |
| 46 | + /*Как только мы нашли дату окончания, не совпадающую с любой из дат начала, мы проверяем в обратном порядке, сколько других столбцов есть |
| 47 | + в течение одного и того же промежутка времени считайте их первыми, если число равно разнице в днях, что означает, что они на самом деле |
| 48 | + связаны. Используйте «группировать по» End_date с MIN(), чтобы найти самую раннюю дату начала, которая связана */ |
| 49 | + (SELECT |
| 50 | + COUNT(*) |
| 51 | + FROM Projects |
| 52 | + WHERE Start_Date BETWEEN P1.Start_Date AND P2.End_Date ) = DATEDIFF(P2.End_Date,P1.Start_Date) |
| 53 | + GROUP BY P2.End_Date) AS P3 |
| 54 | +ORDER by DATEDIFF(P3.ed, P3.sd), P3.sd ; |
16 | 55 | ```
|
17 | 56 |
|
18 | 57 | #### код для hackerrank:
|
19 | 58 | ```sql
|
20 |
| - |
| 59 | +SELECT |
| 60 | + P3.sd,P3.ed |
| 61 | +FROM |
| 62 | + (SELECT |
| 63 | + MIN(P1.Start_Date) AS sd, |
| 64 | + P2.End_Date AS ed |
| 65 | + FROM Projects AS P1 |
| 66 | + INNER JOIN Projects AS P2 |
| 67 | + ON p2.End_Date |
| 68 | + NOT IN (SELECT |
| 69 | + Start_Date |
| 70 | + FROM Projects) |
| 71 | + AND |
| 72 | + (SELECT |
| 73 | + COUNT(*) |
| 74 | + FROM Projects |
| 75 | + WHERE Start_Date BETWEEN P1.Start_Date AND P2.End_Date ) = DATEDIFF(P2.End_Date,P1.Start_Date) |
| 76 | + GROUP BY P2.End_Date) AS P3 |
| 77 | +ORDER by DATEDIFF(P3.ed, P3.sd), P3.sd ; |
21 | 78 | ```
|
22 | 79 |
|
23 | 80 |
|
|
0 commit comments